快速了解ES6Module模块化

ES6 Module

模块,是能够单独命名并独立完成一定功能程序语句的集合

定义听上去高大上,其实在日常项目中几乎每个文件都会用到,甚至很不起眼,

react组件的引用:

// router.js
import { createHashRouter } from 'react-router-dom';
import Contact from './pages/Contact';

const router = createHashRouter([
  {
    path: '/',
    element: <Contact />, 
]);

export { router };
// contact.jsx
export default function Contact() {
  return (
    <div>
      Contact
    </div>
  )
}

以上的exportimport正对应ES6module的两个特征

  • export: 规定模块对外接口
  • import:用于输入其他模块提供的功能

为什么模块化?

  • 代码抽象
  • 代码封装
  • 代码复用
  • 依赖管理

模块化机制

AMD/commonJs两种机制都只能在运行时确定:

AMD

代表库require.js

/** main.js / **/
require.config({
	baseUrl: "js/lib",
	paths: {
	 "jquery": "jquery.min", 
	}
});
require(["jquery"],function($,_){
	//code
});

commonJs

一般用于node之类的服务端。

  • 模块同步加载,只有加载完成才能执行后面的操作
  • 首次加载缓存,再次加载只返回缓存结果
const { read, write } = require('db')

// 等价于
let _db = require('db');
let read= _db.read;
let write  = _db.write ;

ES6module

但ES6静态化,编译时就能确定模块的依赖关系和输入输出

  • 不缓存,只加载需要的方法
  • 编译时,import提升到整个模块的头部(但建议手动放头部)
  • 多次相同导入,只执行一次
foo()

import { foo } from 'my_module';
import { foo } from 'my_module';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你脸上有BUG

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值