1.什么是模块化?
特点(好处):
为什要学习模块化?
模块化: 一个js文件中可以引入另一个js文件的数据。
这个特点是很基础的要求,只要是编程语言都有。而2015年之前,js没有(痛点:多个js都放在一个html文件,而不能相互引用)!
2015年出了ES6,在语法层面就支持模块化,但是浏览器不支持,所以前面学习传统开发时,还是 多个js都放在一个html文件。
当浏览器不支持,可以:
-
先用开发工具(webpack)搭建一个支持模块化的环境
-
在这个环境中写模块化的代码
-
用工具打包代码,然后在浏览器中运行
node.js中的模块化
node.js中的模块分为3大类
1.内置模块(由node.js官方提供,例如:fs,path,http等)
2.自定义模块(用户自己创建的js文件)
3.第三方模块(由第三方开发出来的模块,使用前需要先下载)
加载模块
使用 require() 方法,可以加载需要的内置模块、用户自定义模块、第三方模块进行使用
// 1.加载内置的 fs 模块
const fs = require('fs');
// 2.加载用户的自定义模块
const custom = require('./custom.js');
// 3.加载第三方模块(需要下载~)
const moment = require('momoent');
注意:使用 require() 方法加载其它模块时,会执行被加载模块中的代码。
什么是模块作用域
和函数作用域类似,在自定义模块中定义的变量、方法等成员,只能在当前模块内被访问,这种模块级别的访问限制,叫做模块作用域;
好处:防止了全局变量污染的问题
导出:module.exports , exports
模块规范
-
CommonJS 规范:nodejs中遵守的就是commonjs规范。
-
ES6 模块化规范:(前后端通用的模块化规范;Node.js、Vue、React 中都能使用!)
-
CMD 和 AMD 模块化规范(较少使用): CMD--sea.js, AMD-require.js
-
UMD 叫做通用模块定义规范(Universal Module Definition),它可以通过运行时或者编译时让同一个代码模块在使用 CommonJs、CMD 甚至是 AMD 的项目中运行。它没有自己专有的规范,是集结了 CommonJs、CMD、AMD 的规范于一身
导入:
-
自定义模块:
const xxx = require(模块文件的相对位置) -
内置模块:
const xxx = require(模块的名字) -
第三方模块:
const xxx = require(模块的名字)
3007

被折叠的 条评论
为什么被折叠?



