详解webpack require.ensure与require AMD的区别


Posted in Javascript onDecember 13, 2017

简介

require-ensure和require-amd的区别:

require-amd

说明: 同AMD规范的require函数,使用时传递一个模块数组和回调函数,模块都被下载下来且都被执行后才执行回调函数

语法: require(dependencies: String[], [callback: function(...)])

参数

  1. dependencies: 模块依赖数组
  2. callback: 回调函数

require-ensure

说明: require.ensure在需要的时候才下载依赖的模块,当参数指定的模块都下载下来了(下载下来的模块还没执行),便执行

参数指定的回调函数。require.ensure会创建一个chunk,且可以指定该chunk的名称,如果这个chunk名已经存在了,则将本次依赖的模块合并到已经存在的chunk中,最后这个chunk在webpack构建的时候会单独生成一个文件。

语法: require.ensure(dependencies: String[], callback: function([require]), [chunkName: String])

  1. dependencies: 依赖的模块数组
  2. callback: 回调函数,该函数调用时会传一个require参数
  3. chunkName: 模块名,用于构建时生成文件时命名使用

注意点:requi.ensure的模块只会被下载下来,不会被执行,只有在回调函数使用require(模块名)后,这个模块才会被执行。

示例

require-amd

源代码

webpack.config.amd.js

var path = require("path");
module.exports = {
  entry: "./example.amd.js",
  output: {
    path: path.join(__dirname, "amd"),
    filename: "[name].bundle.js",
    chunkFilename: "[id].chunk.js"
  }
};

example.amd.js

require(["./module1"], function(module1) {
  console.log("aaa");
  var module2 = require("./module2");
  console.log("bbb");
});

module1.js

console.log("module1");
module.exports = 1;

module2.js

console.log("module2");
module.exports = 2;

构建结果

命令行中运行webpack --config webpack.config.amd.js
- main.bundle.js
- example.amd.js
- 1.chunk.js
- module1.js
- module2.js

运行结果

浏览器中运行amd/index.html,控制台输出:

module1
aaa
module2
bbb

require-ensure

源代码

webpack.config.ensure.js

var path = require("path");
module.exports = {
  entry: "./example.ensure.js",
  output: {
    path: path.join(__dirname, "ensure"),
    filename: "[name].bundle.js",
    chunkFilename: "[name].chunk.js"
  }
};

example.ensure.js

require.ensure(["./module1"], function(require) {
  console.log("aaa");
  var module2 = require("./module2");
  console.log("bbb");
  require("./module1");
}, 'test');

module1.js
同上

module2.js
同上

构建结果

命令行中运行webpack --config webpack.config.ensure.js
- main.bundle.js
- example.amd.js
- 1.chunk.js
- module1.js
- module2.js

运行结果

浏览器中运行ensure/index.html,控制台输出:

aaa
module2
bbb
module1

require-ensure-chunk

源代码

webpack.config.ensure.chunk.js

var path = require("path");
module.exports = {
  entry: "./example.ensur.chunk.js",
  output: {
    path: path.join(__dirname, "ensure-chunk"),
    filename: "[name].bundle.js",
    chunkFilename: "[name].chunk.js"
  }
};

example.ensur.chunk.js

require.ensure(["./module1"], function(require) {
  console.log("aaa");
  require("./module1");
  console.log("bbb");
}, 'common');

require.ensure(["./module2"], function(require) {
  console.log("ccc");
  require("./module2");
  console.log("ddd");
}, 'common');

module1.js
同上

module2.js
同上

构建结果

命令行中运行webpack --config webpack.config.ensure.js
- main.bundle.js
- example.amd.js
- 1.chunk.js
- module1.js
- module2.js

运行结果

浏览器中运行ensure/index.html,控制台输出:

aaa
module1
bbb
ccc
1module2
ddd

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js类中的公有变量和私有变量
Jul 24 Javascript
锋利的jQuery 第三章章节总结的例子
Mar 23 Javascript
node.js应用后台守护进程管理器Forever安装和使用实例
Jun 01 Javascript
学习JavaScript设计模式(策略模式)
Nov 26 Javascript
js中字符串编码函数escape()、encodeURI()、encodeURIComponent()区别详解
Apr 01 Javascript
JavaScript 函数的执行过程
May 09 Javascript
JavaScript中三个等号和两个等号你了解多少
Jul 04 Javascript
jQuery实现菜单栏导航效果
Aug 15 jQuery
vue监听键盘事件的快捷方法【推荐】
Jul 11 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
Apr 23 Javascript
Vue中的this.$options.data()和this.$data用法说明
Jul 26 Javascript
VUE 实现element upload上传图片到阿里云
Aug 12 Javascript
vue登录路由验证的实现
Dec 13 #Javascript
vue按需加载组件webpack require.ensure的方法
Dec 13 #Javascript
vue实现某元素吸顶或固定位置显示(监听滚动事件)
Dec 13 #Javascript
vue组件中使用iframe元素的示例代码
Dec 13 #Javascript
vue中路由验证和相应拦截的使用详解
Dec 13 #Javascript
vue实现nav导航栏的方法
Dec 13 #Javascript
vue实现导航栏效果(选中状态刷新不消失)
Dec 13 #Javascript
You might like
德劲1104的电路分析与改良
2021/03/01 无线电
PHP删除数组中的特定元素的代码
2012/06/28 PHP
PDO版本问题 Invalid parameter number: no parameters were bound
2013/01/06 PHP
基于PHP技术开发客服工单系统
2016/01/06 PHP
win10 apache配置虚拟主机后localhost无法使用的解决方法
2018/01/27 PHP
PHP使用Curl实现模拟登录及抓取数据功能示例
2018/04/27 PHP
Javascript中的数学函数集合
2007/05/08 Javascript
jQuery在html有效在jsp无效的原因及解决方法
2013/08/02 Javascript
jQuery 属性选择器element[herf*='value']使用示例
2013/10/20 Javascript
深入分析JSON编码格式提交表单数据
2015/06/25 Javascript
20分钟打造属于你的Bootstrap站点
2016/07/27 Javascript
关于JS Lodop打印插件打印Bootstrap样式错乱问题的解决方案
2016/12/23 Javascript
JS实现的模仿QQ头像资料卡显示与隐藏效果
2017/04/07 Javascript
使用Vue-Router 2实现路由功能实例详解
2017/11/14 Javascript
JS文件中加载jquery.js的实例代码
2018/05/05 jQuery
vue this.reload 方法 配置
2018/09/12 Javascript
在小程序中使用canvas的方法示例
2018/09/17 Javascript
JavaScript使用闭包模仿块级作用域操作示例
2019/01/21 Javascript
使用vue制作滑动标签
2019/09/21 Javascript
基于JavaScript获取url参数2种方法
2020/04/17 Javascript
[02:24]DOTA2痛苦女王 英雄基础教程
2013/11/26 DOTA
python字典的常用操作方法小结
2016/05/16 Python
Python实现解析Bit Torrent种子文件内容的方法
2017/08/29 Python
详解使用 pyenv 管理多个版本 python 环境
2017/10/19 Python
简单介绍python封装的基本知识
2019/08/10 Python
python生成器/yield协程/gevent写简单的图片下载器功能示例
2019/10/28 Python
解决tensorflow训练时内存持续增加并占满的问题
2020/01/19 Python
python GUI框架pyqt5 对图片进行流式布局的方法(瀑布流flowlayout)
2020/03/12 Python
Python3 pickle对象串行化代码实例解析
2020/03/23 Python
PyCharm设置注释字体颜色以及是否倾斜的操作
2020/09/16 Python
详解使用python爬取抖音app视频(appium可以操控手机)
2021/01/26 Python
CSS实现进度条和订单进度条的示例
2020/11/05 HTML / CSS
西部世纪面试题
2014/12/05 面试题
家长会演讲稿
2014/04/26 职场文书
班主任经验交流心得体会
2015/11/02 职场文书
Vue + iView实现Excel上传功能的完整代码
2021/06/22 Vue.js