JS模块的艺术

本文详细介绍了ES6的模块语法,包括export和import的基本用法,as和*的语法特性,以及模块组织形式的扩展,如单文件双模式导出和多文件索引。通过实例解析了模块导出和导入的编译过程,帮助读者掌握模块化编程的关键知识点。
摘要由CSDN通过智能技术生成

ES6的module导出引入总结。

基本module语法

  ES6提供了exportimport语法,给予了JS模块化代码组织形式的能力。export语句用于从模块中导出函数、对象或原始值,以便其他程序可以通过import语句使用它们。

export

  我们假设我们拥有一个fileA.js的文件,它向外export了这些:

// fileA.js
export const DEMO_VALUE = '123';
export function demoFunction(param) {
    console.log(param); }
export default 123

  export有两种导出形式。一种是使用export语句接上const/let/var/function等声明变量函数的语句向模块外导出值。一个文件内部可以存在多个export语句。另一种是使用export default直接加上值(不接声明语句)的方式向模块外导出值。一个文件内部只能存在一个export default语句。

  我们用babel来看一下实际上export实际转化成了什么。

// export const DEMO_VALUE = '123';
// export default 123
// babel transform
Object.defineProperty(exports, "__esModule", {
   
  value: true
});
exports.default = exports.DEMO_VALUE = void 0;
var DEMO_VALUE = '123';
exports.DEMO_VALUE = DEMO_VALUE;
var _default = 123;
exports.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值