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

简介

require-ensurerequire-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

rush: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

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

module1.js

rush:js;"> console.log("module1"); module.exports = 1;

module2.js

rush: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,控制台输出

rush:plain;"> module1 aaa module2 bbb

require-ensure

代码

webpack.config.ensure.js

rush:js;"> var path = require("path"); module.exports = { entry: "./example.ensure.js","ensure"),chunkFilename: "[name].chunk.js" } };

example.ensure.js

rush: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

rush:js;"> var path = require("path"); module.exports = { entry: "./example.ensur.chunk.js","ensure-chunk"),chunkFilename: "[name].chunk.js" } };

example.ensur.chunk.js

rush: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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...