前端模块化(CMJ和ESM)

1. 为什么要模块化

  1. 把具有不同功能的版块封装为不同的模块,比如把涉及到网络请求的函数全都写在一个network.js文件里,把一些工具类的函数写在tool.js文件里,框架里的每一个组件都占据一个.vue文件,避免所有代码都写到一起,难以管理,同时还可以提高代码的复用率
  2. 通常一个文件就是一个模块,有自己的作用域,只向外暴露特定的变量和函数和类。

2. 模块化规范

目前流行的js模块化规范有CommonJS、AMD、CMD以及ES6的模块系统

1. CommonJs

  1. NodeJS采用CommonJS规范实现了模块系统
  2. CommonJS规范
  • CommonJS规范规定了如何定义一个模块, 如何暴露(导出)模块中的变量函数, 以及如何使用定义好的模块
    - 在CommonJS规范中一个文件就是一个模块
    - 在CommonJS规范中每个文件中的变量函数都是私有的,对其他文件不可见的
    - 在CommonJS规范中每个文件中的变量函数必须通过exports暴露(导出)之后其它文件才可以使用
    - 在CommonJS规范中想要使用其它文件暴露的变量函数必须通过require()导入模块才可以使用

2. Node模块中暴露数据的几种方法

  • exports xxx =(暴露出去一个对象)
    a.js

每一个node执行一个文件时,会给这个文件内生成一个exports和module对象

//在模块里面编写私有的变量和函数,通过exports暴露出去,记住,暴露出去的是一个对象
let name = 'mike'
function sum() {
   
    console.log(3);
}
exports.name = name
exports.sum = sum

b.js

let moduleA = require('./s')
console.log(moduleA);

在这里插入图片描述

  • module.exports.xxx
    a.js
let name = 'mike'
function sum() {
   
    console.log(3);
}
module
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值