JavaScript

JavaScript 模块化

2021-07-07  本文已影响0人  consolelog

ES6 规范

单个导出

//导出
export let name1 = 'zhangsan';
export let name2 = 'lisi';

//导入
import {name1, name2} from './test.js';

批量导出

//导出
let name1 = 'zhangsan';
let name2 = 'lisi';
let name3 = 'wangwu';
export {name1, name2, name3}

//导入
import {name1, name2, name3} from './test.js';

取别名

//导出
let name1 = 'zhangsan';
let name2 = 'lisi';
let name3 = 'wangwu';
export {name1 as n1, name2 as n2, name3 as n3}

//导入
import * as name from './test.js';

默认导出,一个模块只能有一个默认导出,对于默认导出,导入的名称可以和导出的名称不一致

//导出
export default function(){
    console.log('默认导出');
}

//导入
import func from './test.mjs';
func();
//导出
export default {
    func(){
        console.log('默认导出');
    },
    name:'zhangsan',
    age:22
}

//导入
import obj from './a.mjs';

obj.func();
console.log(obj.name);
console.log(obj.age);

CommonJS 规范

//导出
module.exports.name = 'zhangsan'
module.exports.age = 'zhangsan'
module.exports.func = function(){ console.log('commonJS规范') }

//导入
const  obj = require('./a');

console.log(obj.name);
console.log(obj.age);
obj.func();

//或者
const { name, age, func } = require('./a');

console.log(name);
console.log(age);
func();

上一篇 下一篇

猜你喜欢

热点阅读