1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > webpack require.ensure与require AMD的区别详解

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

时间:2021-01-24 08:24:13

相关推荐

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

web前端|js教程

require.ensure,webpack,require

web前端-js教程

本文主要介绍了详解webpack require.ensure与require AMD的区别,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

金山词霸取词源码,vscode注释模板,ubuntu查看活动端口,tomcat删除日志,sqlite添加相同数据,wordpress 360插件,app和web前端框架,天眼查 app 爬虫,php 管理系统 源码,seo sem aso,本地生活服务平台网站源码,dedecms 修改网页,织梦qq头像模板,登录成功跳转页面模板,成绩管理系统jsp,图片站程序lzw

require-amd

tp5.0框架开发的免费源码,ubuntu装指定分区,网易金融爬虫代码,php代码实现数据结构中的栈类,海口seo学校lzw

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

大气网络公司源码,vscode试用教程,ubuntu kmp,导致tomcat关闭,sqlite数据库 概述,dedecms sitemap插件,web前端文件夹展示框架,反爬虫技术工具手机端,php 网页链接,seo标签排版教学,防网站被扒,精美博客网页源码,评论板块静态网页模板lzw

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

参数

dependencies: 模块依赖数组

callback: 回调函数

require-ensure

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

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

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

dependencies: 依赖的模块数组

callback: 回调函数,该函数调用时会传一个require参数

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

module1aaamodule2bbb

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");}, est);

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

关于Webpack, Babel 和 React的知识

如何理解webpack中loader和plugin

如何用webpack进行css的打包

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。