JS模块化

作者: 88b61f4ab233 | 来源:发表于2018-10-24 22:24 被阅读5次

一、理解

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

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

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

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

二、模块化规范

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

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

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

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

第三方模块:xxx为模块名

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

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

暴露的模块 本质是 exports 对象

exports本身是一个空对象 exports.xxx = 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 是打包输出的文件)

页面使用引入:

<script type="text/javascript" src="js/dist/bundle.js"></script> (浏览器真正跑的是打包生成的文件)

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

相关文章

  • 模块化开发

    js模块化开发vue模块化开发

  • Javascript 模块化

    Javascript 模块化发展的历史精读 js 模块化发展直接定义依赖 (1999): 由于当时 js 文件非常...

  • js模块化规范

    title: js模块化date: 2019-01-30 17:49:22tags: js 1.无模块化 缺点:1...

  • js 模块化

    尚硅谷_JS模块化 笔记

  • 06Vue的前端工程化

    Vue的前端工程化 一 模块化规范 1.1模块化规范举例 浏览器端JS模块化规范:AMD,CMD 服务器端JS模块...

  • 模块化开发

    什么是模块化? 模块化就是讲js文件按照功能分离,根据需求引入不同的文件中。源于服务器端。 js模块化方案有AMD...

  • 前端模块化

    在学node.js, 实际上就是基于common.js开发的,所以了解了一下模块化开发。 JS的模块化初衷和所有语...

  • 04-webpack核心基础-ES6模块化

    一、模块化概述 在ES6出现之前,JS不像其他语言拥有“模块化”这一概念,于是为了支持JS模块化我们使用类、立即执...

  • 前端javascript模块化

    JavaScript js 模块化 关于js模块化的理解写法一 写法二 写法三 写发四(不推荐) 写发五 (错误写...

  • 做了这么久的前端开发,听过Css模块化开发么?

    说起前端模块化开发,大部分人可能只会想到js模块化开发吧,网上也确实有各种各样的js模块化方法,但是鲜有谈论Css...

网友评论

    本文标题:JS模块化

    本文链接:https://www.haomeiwen.com/subject/gakftqtx.html