es6—module模块

0.模块化相关

1.浏览器的JS模块化 :AMD,CMD
2.服务器端:CommonJS,浏览器默认支持
3.大一统模块化规范 - ES6模块化——module
4. node默认支持commonjs,但对es6支持有限,需要通过 babel【语法转化工具】 在node中体验es6模块化,

0.babel配置

在这里插入图片描述
之后允许使用高级es6语法

1.使用原因

  1. 大程序拆分为相互依赖小文件,再简单方法拼接
  2. 好处:1>避免变量污染,命名冲突 2>提供代码的复用率、维护性 3>依赖关系管理
    在这里插入图片描述
    在这里插入图片描述

2.基本语法

1.1 导出 export

// 导出暴露变量
let name = "GYP";
let age = 20;
export { name, age }

// 暴露对象
let obj = {
    name: '郭研苹',
    age: 20
}
export { obj };

// 3.1 导出暴露函数
export function addFn(a, b) {
    console.log(a + b);
}

function fn1() {
    console.log(fn1);
}

function fn2() {
    console.log(fn2);
}
export { fn1 as tempfn1, fn2 as tempfn2 }

1.2 导入import m1,{s1,s2} from ’ ’

m1-默认导入,{s1}按需导入

//0.不必导出,直接导入
//m2.js:
for(let i = 0;i < 3;i++) {
	log(i)l
}
//index.js
import './m2.js'//0,1,2
// 1.接受导入变量,不可修改
import { name, age } from './export.js'
console.log(`前辈您好,我叫${name},今年${age}`);
// GYP,20

// 2.导入对象属性,可以修改
import { obj } from './export.js'
obj.age = 18;
console.log(obj);
console.log(`你好,我叫${obj.name},今年${obj.age}`);
//郭研苹 18

// 3.导入函数 函数名 as 别名
add(20, 30); //存在变量提升
import { addFn as add } from './export.js'
//50

// 3.2 多个函数导入
import { tempfn1, tempfn2 } from './export.js';
tempfn1();
tempfn2();
//打印以上函数

注意

  1. import 导入前需要 export 导出在终端进行npx babel -node
  2. 每个js中仅允许唯一一次默认导出 export default,但可以有多次 按需导出
  3. 未导出就导入,终端出现 undefined

1.3注意:module静态导入,

不能使用表达式和变量内些运行时才能看到结果导入
错误示范;

// 错误示范1
let path = './export.js'
import tempfn1 from path;
//错误示范2
if(l == 1) {
	import {addFn1 as test} from './export.js'
}

2.1 整体加载

export.js

function fn1(args) {
    return args;
}

function fn2(...args) {
    return (args) * 2;
}
export { fn1, fn2 }

import.js

//全部导入对象中
import * as obj from './export.js';
console.log(obj);
console.log('fn1', obj.fn1(123)); // fn1 123
console.log('fn2', obj.fn2(6)); // fn2 12

3.1 默认输出,导入时不加 { }

export default function() {}

export default class Person {
    constructor(name) {
        this.name = name;
    }
}

import

import Person from './export.js';
let p = new Person('gyp');
console.log(p);
// Person iname: 'gyp '3

正常输出,导入时加{ }

4.1 复合写法

public.js

export let number = 10;

export.js

export {number} from 'public.js'

import.js

import {number} from './export.js'
log(number)//10

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值