ES6的模块化

ES6模块化是JavaScript的一种组织代码的方式,它允许开发者将代码分割成多个独立的部分(模块),每个模块有自己的作用域和接口,模块之间可以通过导入(import)和导出(export)进行相互引用。

基本语法

导出(Export)

在ES6中,一个模块可以导出多个值,如变量、函数、对象等。这些值可以通过export关键字进行导出。

javascript 复制代码
// 导出变量
export const name = 'ES6 Module';

// 导出函数
export function sayHello() {
  console.log('Hello, ES6 Module!');
}

导入(Import)

其他模块可以通过import关键字导入模块导出的值。

javascript 复制代码
// 导入模块
import { name, sayHello } from './module.js';

console.log(name); // 输出 'ES6 Module'
sayHello(); // 输出 'Hello, ES6 Module!'

默认导出和导入

每个模块可以有一个默认导出,使用export default进行导出。默认导出的值可以在导入时使用任意名称。

javascript 复制代码
// module.js
export default function() {
  console.log('This is the default export');
}

// main.js
import myDefaultFunction from './module.js';

myDefaultFunction(); // 输出 'This is the default export'

模块的整体加载

除了指定加载某个输出值,还可以使用整体加载,即用星号(*)指定一个对象,所有输出值都加载在这个对象上面。

JavaScript

javascript 复制代码
// lib.js
export function func1(){...}
export function func2(){...}

// main.js
import * as lib from './lib.js';

console.log(lib.func1);
console.log(lib.func2);

在上面的代码中,main.js模块加载了lib.js模块的所有导出值,它们都会挂载在lib对象上。

注意事项

  1. importexport命令只能在模块的顶层,不能在代码块(如:if语句、for循环等)中使用。
  2. 导入的模块是只读的,不能修改导入的值。
相关推荐
IT_陈寒4 分钟前
Java性能调优实战:7个让GC效率提升50%的关键参数设置
前端·人工智能·后端
前端小菜袅18 分钟前
uniapp配置自动导入uni生命周期等方法
前端·javascript·uni-app
Apifox20 分钟前
如何在 Apifox 中通过 AI 一键生成几十个测试用例?
前端·后端·ai编程
你真的可爱呀21 分钟前
uniapp学习【整体实践】
前端·学习·uni-app·实践
一枚前端小能手28 分钟前
「周更第7期」实用JS库推荐:Vite
前端·javascript·vite
小中123444 分钟前
异步请求的性能提升
前端
我是天龙_绍1 小时前
渐变层生成器——直接用鼠标拖拽就可以调整渐变层的各种参数,然后可以导出为svg格式
前端
我是天龙_绍1 小时前
Easing 曲线 easings.net
前端
知识分享小能手1 小时前
微信小程序入门学习教程,从入门到精通,电影之家小程序项目知识点详解 (17)
前端·javascript·学习·微信小程序·小程序·前端框架·vue
訾博ZiBo1 小时前
React组件复用导致的闪烁问题及通用解决方案
前端