最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

对于JS模块化的解析

来源:懂视网 责编:小采 时间:2020-11-27 19:33:54
文档

对于JS模块化的解析

对于JS模块化的解析:这篇文章主要介绍了关于对于JS模块化的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下一、理解1、什么是模块、模块化?将一个复杂的程序依据一定的规范封装成几个文件,并进行组合在一起2、为什么要模块化?降低复杂度,提高解耦性,部
推荐度:
导读对于JS模块化的解析:这篇文章主要介绍了关于对于JS模块化的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下一、理解1、什么是模块、模块化?将一个复杂的程序依据一定的规范封装成几个文件,并进行组合在一起2、为什么要模块化?降低复杂度,提高解耦性,部

这篇文章主要介绍了关于对于JS模块化的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

一、理解

1、什么是模块、模块化?

将一个复杂的程序依据一定的规范封装成几个文件,并进行组合在一起

2、为什么要模块化?

降低复杂度,提高解耦性,部署方便

3、模块化的好处

  • 避免命名冲突(减少命名空间污染)

  • 更好的分离,按需加载

  • 更高复用性

  • 高可维护性

  • 4、页面引入加载script

    二、模块化规范

    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

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    对于JS模块化的解析

    对于JS模块化的解析:这篇文章主要介绍了关于对于JS模块化的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下一、理解1、什么是模块、模块化?将一个复杂的程序依据一定的规范封装成几个文件,并进行组合在一起2、为什么要模块化?降低复杂度,提高解耦性,部
    推荐度:
    标签: js 解析 模块化
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top