登录  /  注册
首页 > web前端 > js教程 > 正文

对于JS模块化的解析

不言
发布: 2018-07-11 11:04:27
原创
1186人浏览过

这篇文章主要介绍了关于对于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 是打包输出的文件)

页面使用引入:

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

对于Javascript加载的解析

关于javascrip的立即执行函数的解析

以上就是对于JS模块化的解析的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号