博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webpack学习笔记(1)-模块化
阅读量:6837 次
发布时间:2019-06-26

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

模块化

模块化是指把一个复杂的系统分解到多个模块以方便编码。

很久以前,开发网页要通过命名空间的方式来组织代码,例如 jQuery 库把它的API都放在了 window.$ 下,在加载完 jQuery 后其他模块再通过 window.$ 去使用 jQuery。 这样做有很多问题,其中包括:

命名空间冲突,两个库可能会使用同一个名称,例如 Zepto 也被放在 window.$ 下;

无法合理地管理项目的依赖和版本;
无法方便地控制依赖的加载顺序。
当项目变大时这种方式将变得难以维护,需要用模块化的思想来组织代码。

script 标签

最原始的模块实现方式是通过在页面中插入多个 script 标签。

全局的作用域

立即执行函数表达式

(function() {  // foobar 并不会暴露在全局作用域  var foobar = 'Hello IIFE!';  console.log(foobar);})()

命名空间

库名.类别名.方法名

var NameSpace = {}NameSpace.type = NameSpace.type || {}NameSpace.type.method = function(){}

CommonJS 与 Node.js 模块系统

  • 一个文件为一个模块
  • 通过 module.exports 暴露模块接口
exports.getSum = function(a, b) {  return a + b;}
  • 通过 require 引入模块
const math = require('./math');
  • CommonJS 规范的流行得益于 Node.js 采用了这种方式
  • 同步执行
  • 无法直接运行在浏览器环境下,必须通过工具转换成标准的 ES5。

AMD

  • Async Module Definition
  • 使用 define 定义模块
  • 使用 require 加载模块
/ 定义一个求和的模块define('getSum', ['math'], function(math) {  return function(a, b) {    console.log('sum: ' + math.sum(a, b));  }});
  • 应用RequireJS
  • 依赖前置,提前执行
  • 异步加载依赖
  • JavaScript 运行环境没有原生支持 AMD,需要先导入实现了 AMD 的库后才能正常使用

clipboard.png

CMD

  • Common Module Definition
  • 一个文件为一个模块
  • 使用define 来定义一个模块
  • 使用require 来加载一个模块
  • 应用(SeaJS)
  • 尽可能懒执行

clipboard.png

ES6 Module

  • 一个文件一个模块
  • export / import
  • import()
  • 目前无法直接运行在大部分 JavaScript 运行环境下,必须通过工具转换成标准的 ES5 后才能正常运行。

clipboard.png

clipboard.png

clipboard.png

clipboard.png

Webpack 支持

  • AMD (RequireJS)
  • ES Modules (推荐的主流)
  • CommonJS(主流)

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

你可能感兴趣的文章
【阿里云总监课第四期】时髦的云原生应用怎么写?
查看>>
摘自ubantuer-Linux防火墙iptables学习笔记(三)iptables命令详解和举例
查看>>
876. Middle of the Linked List - LeetCode
查看>>
fatal error LNK1123: 转换到 COFF 期间失败
查看>>
提升tomcat服务器性能的七条经验
查看>>
访客门禁系统供应商 首选钱林厂家
查看>>
sqlserver安装和简单的使用
查看>>
android客户端访问服务端tomcat
查看>>
VC/MFC Tips
查看>>
加密和解密技术基础、PKI及创建私有CA
查看>>
Windows 注册和取消注册一个dll或者ocx
查看>>
vim对nginx的语法高亮设置
查看>>
ApiCloud云端管理平台(v.20151022)
查看>>
MVC3----筛选数据(BeginForm:输出form表单)
查看>>
我的友情链接
查看>>
基于Android平台的多分辨率解决方案[图]
查看>>
定向广播和本地广播
查看>>
ubuntu下安装nagios
查看>>
JVM致命错误日志(hs_err_pid.log)分析
查看>>
hdfs.DFSClient: Exception in createBlockOutputStre
查看>>