当前位置: 首页 > news >正文

ES6 Module 的语法(十二)

ES6(ECMAScript 2015)引入了模块(Modules)的概念,使得JavaScript代码可以更容易地组织和复用。

1. export 关键字

命名导出 (Named Exports)
你可以使用 export 关键字导出多个变量、函数或类。

// module.js
export const name = 'John';
export function greet() {console.log('Hello, ' + name);
}
export class Person {constructor(name) {this.name = name;}
}

默认导出 (Default Export)
每个模块只能有一个默认导出,用 export default 来实现。

// module.js
export default function() {console.log('This is the default export');
}

2. import 关键字

导入命名导出 (Importing Named Exports)
使用 import 关键字可以导入其他模块的命名导出。

// main.js
import { name, greet, Person } from './module.js';console.log(name); // John
greet(); // Hello, John
const person = new Person('Jane');
console.log(person.name); // Jane

导入默认导出 (Importing Default Export)
导入默认导出时,不需要使用大括号。

// main.js
import myFunction from './module.js';myFunction(); // This is the default export

导入所有导出 (Importing All Exports)
可以使用 * as 语法导入一个模块的所有导出,并将其绑定到一个对象上。

// main.js
import * as myModule from './module.js';console.log(myModule.name); // John
myModule.greet(); // Hello, John
const person = new myModule.Person('Jane');
console.log(person.name); // Jane

3. 重新导出 (Re-Exporting)

可以从一个模块中重新导出另一个模块的导出。

// module1.js
export const a = 1;
export const b = 2;// module2.js
export { a, b } from './module1.js';
export const c = 3;// main.js
import { a, b, c } from './module2.js';console.log(a, b, c); // 1 2 3

4. 动态导入 (Dynamic Import)

ES2020引入了动态导入,使用 import() 函数可以在运行时按需加载模块。

// main.js
async function loadModule() {const module = await import('./module.js');module.greet(); // Hello, John
}loadModule();

5. 具有副作用的模块 (Modules with Side Effects)

一些模块在导入时会执行一些代码,这些模块被称为具有副作用的模块。

// sideEffectModule.js
console.log('Module loaded');// main.js
import './sideEffectModule.js'; // Module loaded

6. export 和 import 的高级用法

导出和导入时重命名
可以在导出和导入时使用 as 关键字进行重命名。

// module.js
const name = 'John';
function greet() {console.log('Hello, ' + name);
}
export { name as userName, greet as sayHello };// main.js
import { userName, sayHello } from './module.js';console.log(userName); // John
sayHello(); // Hello, John

导出时使用默认导出和命名导出

// module.js
export const name = 'John';
export default function() {console.log('This is the default export');
}// main.js
import defaultFunction, { name } from './module.js';console.log(name); // John
defaultFunction(); // This is the default export
http://www.lryc.cn/news/399881.html

相关文章:

  • Redis 主从复制,哨兵与集群
  • CV05_深度学习模块之间的缝合教学(1)
  • 【密码学】公钥密码的基本概念
  • 【前端项目笔记】10 项目优化上线
  • Qt基础控件总结—多页面切换(QStackWidget类、QTabBar类和QTabWidget类)
  • 团队融合与业务突破
  • mybatilsplaus 常用注解
  • vue引入sm-crypto通过sm4对文件进行加解密,用户输入密码
  • vue3实现无缝滚动列表(大屏数据轮播场景)
  • element ui ts table重置排序
  • python热门面试题三
  • sql monitoring 长SQL ASH AWR 都没有 未Commit or export to csv
  • 算法学习day12(动态规划)
  • Vue 3 <script setup> 使用v-bind(或简写为 :)来动态绑定图片的 src 属性
  • ​前端Vue自定义签到获取积分弹框组件设计与实现
  • 闲置服务器废物利用_离线下载_私人影院_个人博客_私人云笔记_文件服务器
  • 【Python学习笔记】调参工具Optuna + 泰坦尼克号案例
  • GPT带我学-设计模式13-策略模式
  • 【Linux】Ubuntu配置JDK环境、MySQL环境
  • 【ElasticSearch】ES 5.6.15 向量插件支持
  • Kafka 高并发设计之数据压缩与批量消息处理
  • 设计模式使用场景实现示例及优缺点(行为型模式——模板方法模式)
  • ETL数据集成丨主流ETL工具(ETLCloud、DataX、Kettle)数据传输性能大PK
  • eNSP:防火墙设置模拟公司配置(二)
  • vue3 两个组件之间传值
  • 基于matlab的深度学习案例及基础知识专栏前言
  • 机器学习——L1 L2 范数 —>L1 L2正则化
  • 大模型时代,还需要跨端framework吗?
  • ASP.NET Core----基础学习05----将数据传递给视图文件的五种情况
  • Flutter实现局部刷新的几种方式