博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS模块化
阅读量:6243 次
发布时间:2019-06-22

本文共 1837 字,大约阅读时间需要 6 分钟。

###一、理解 1、什么是模块、模块化? 将一个复杂的程序依据一定的规范封装成几个文件,并进行组合在一起

2、为什么要模块化? 降低复杂度,提高解耦性,部署方便

3、模块化的好处 避免命名冲突(减少命名空间污染) 更好的分离,按需加载 更高复用性 高可维护性 4、页面引入加载script 模块的使用 举例来说:前端框架layui 的js部分就是采用模块化(用的自己定义的模块化方法)

layui.use就是引入模块 layui,define就是定义模块

###二、模块化规范 1、CommonJS(node根据该规范编写) 说明: 每一个文件都可以当做一个模块

在服务器端:模块的加载 是运行时同步加载的

在浏览器端:模块需要提前编译打包处理

基本语法: 模块引入:require(xxx)

  第三方模块:xxx为模块名

  自定义模块:xxx为模块文件路径

暴露模块: = value 和 module.exports = value

  暴露的模块 本质是 exports 对象

  exports本身是一个空对象 = value是给exports对象添加属性或方法

  module.exports = value 是直接用value新对象来覆盖原来的空对象

实现: 服务器端实现:Node.js

浏览器端实现:Browserify (CommonJS的浏览器端的打包工具)

下载安装browserify

  全局:npm install browserify -g

  局部:npm install browserify --save-dev

定义模块代码(js文件代码 并暴露相应内容)

引入模块 在app.js 中用require引入模块 但是浏览器不认识require方法,需要打包处理js

  在根目录下 终端输入 browserify js/src/app.js -o js/dist/bundle.js (js/src/app.js源文件 js/dist/bundle.js 是打包输出的文件)

页面使用引入:

 (浏览器真正跑的是打包生成的文件)复制代码

2、AMD 说明: 专门用于浏览器端的模块化规范,模块的加载是异步的

基本语法: 定义暴露模块:

  //定义没有依赖的模块:  define(function(){    return 模块  })  //定义有依赖的模块:  define(['module1','module2'],function(m1,m2){    return 模块  })引入使用模块:   require(['module1','module2'],function(m1,m2){    使用m1/m2  })复制代码

实现(浏览器端): Require.js

3、CMD(了解) 说明:专门用于浏览器端,模块的加载是异步的,模块使用时才会加载执行 基本语法: 定义暴露模块:

  //定义没有依赖的模块:  define(function(require,exports,module){    exports.xxx = value    module.exports = value  })复制代码

  //定义有依赖的模块:

  define(function(require,exports,module){    //引入依赖模块(同步)    var module2 = require("./module2")    //引入依赖模块(异步)    require.async("./module3",function(m3){    })    //暴露模块    exports.xxx = value  })复制代码

引入使用模块:

  require(function(require){    var m1 = require('./module1')    var m4 = require('./module4')    m1.show()    m4.show()  })复制代码

实现(浏览器端):Sea.js 4、ES6 说明:依赖模块需要编译打包处理 语法:   导出模块:export xxx

  引入模块:import xxx from "url"

页面引入

实现(浏览器端):   使用Babel将ES6编译为ES5代码

  使用Browserify编译打包js

转载地址:http://fvpia.baihongyu.com/

你可能感兴趣的文章
《AngularJS深度剖析与最佳实践》简介
查看>>
Android----------WindowManager
查看>>
通过DAC来连接SQL Server
查看>>
Oracle11G 卸载步骤
查看>>
Mars说光场(3)— 光场采集
查看>>
kettle与各数据库建立链接的链接字符串
查看>>
Android--调用系统照相机拍照与摄像
查看>>
【OpenCV学习】利用HandVu进行手部动作识别分析
查看>>
Ubuntu下安装配置JDK1.7
查看>>
AngularJS快速入门指南15:API
查看>>
安装惠普M1136打印机一直处于“新设备已连接”状态怎么办?
查看>>
android88 录音机
查看>>
美国诚实签经验(最全集合)
查看>>
HttpContext.Current:异步模式下的疑似陷阱之源
查看>>
《Java与模式》- 创建型模式
查看>>
[Android]使用Kotlin开发Android(二)
查看>>
php将对象数组转成普通数组
查看>>
org.gradle.process.internal.ExecException: Process 'command 'C:\Program Files (x86)\Java\jdk1.7.0_7
查看>>
Python 中的 if __name__ == '__main__' 该如何理解(1)
查看>>
Qt之对话框设计——利用QPalette改变控件颜色
查看>>