入口起点【Entry Points】:

单个入口(简写)语法

用法:entry: string|Array<string>

例子(webpack.config.js)

const config = {
entry: './path/to/my/entry/file.js'
}; module.exports = config;

entry 属性的单个入口语法,是下面的简写:

const config = {
entry: {
main: './path/to/my/entry/file.js'
}
};

当你向 entry 传入一个数组时会发生什么?向 entry 属性传入「文件路径(file path)数组」将创建“多个主入口(multi-main entry)”。在你想要多个依赖文件一起注入,并且将它们的依赖导向(graph)到一个“chunk”时,传入数组的方式就很有用。

当你正在寻找为「只有一个入口起点的应用程序或工具(即 library)」快速设置 webpack 配置的时候,这会是个很不错的选择。

然而,使用此语法在扩展配置时有失灵活性。

对象语法

用法:entry: {[entryChunkName: string]: string|Array<string>}

例子(webpack.config.js)

const config = {
entry: {
app: './src/app.js',
vendors: './src/vendors.js'
}
};

对象语法会比较繁琐。然而,这是应用程序中定义入口的最可扩展的方式。

“可扩展的 webpack 配置”是指,可重用并且可以与其他配置组合使用。这是一种流行的技术,用于将关注点(concern)从环境(environment)、构建目标(build target)、运行时(runtime)中分离。然后使用专门的工具(如 webpack-merge)将它们合并。

常见场景

分离 应用程序(app) 和 第三方库(vendor) 入口

例子(webpack.config.js)

const config = {
entry: {
app: './src/app.js',
vendors: './src/vendors.js'
}
};

这是什么?从表面上看,这告诉我们 webpack 从 app.js 和 vendors.js 开始创建依赖图(dependency graph)。

这些依赖图是彼此完全分离、互相独立的(每个 bundle 中都有一个 webpack 引导(bootstrap))。

这种方式比较常见于,只有一个入口起点(不包括 vendor)的单页应用程序(single page application)中。

为什么?此设置允许你使用 CommonsChunkPlugin 从「应用程序 bundle」中提取 vendor 引用(vendor reference) 到 vendor bundle,并把引用 vendor 的部分替换为 __webpack_require__()调用。

如果应用程序 bundle 中没有 vendor 代码,那么你可以在 webpack 中实现被称为长效缓存的通用模式。

多页面应用程序

例子(webpack.config.js)

const config = {
entry: {
pageOne: './src/pageOne/index.js',
pageTwo: './src/pageTwo/index.js',
pageThree: './src/pageThree/index.js'
}
};

这是什么?我们告诉 webpack 需要 3 个独立分离的依赖图(如上面的示例)。

为什么?在多页应用中,(译注:每当页面跳转时)服务器将为你获取一个新的 HTML 文档。

页面重新加载新文档,并且资源被重新下载。

然而,这给了我们特殊的机会去做很多事:

  • 使用 CommonsChunkPlugin 为每个页面间的应用程序共享代码创建 bundle。由于入口起点增多,多页应用能够复用入口起点之间的大量代码/模块,从而可以极大地从这些技术中受益。

最新文章

  1. [译]Godot系列教程四 - 编写脚本
  2. Sigmaplot 13 破解版什么地方可以下载
  3. nios II--实验4——按键中断硬件部分
  4. MySQL Thread Pool: Problem Definition
  5. Android中ListView中有button,checkbox,GridView时事件问题
  6. mongod的主要参数解释
  7. JLink 在J-Flash ARM批处理自动下载
  8. 如何去掉&#160;Discuz标题后缀power&#160;by&#160;discuz
  9. Node.js开发环境介绍-调试工具
  10. Android Studio 1.0 苹果电脑安装配置
  11. MyEclipse下一个XFire发展Webservice示例
  12. Visual Studio 2015 &amp; C#6.0 试用报告,持续更新。
  13. GeoServer初识与安装
  14. python 列表(list)常用操作
  15. 存储那些事儿(一):异构虚拟化一种实现SMIS
  16. Android 支付密码输入框,自定义EditText实现密码输入框功能;
  17. 【Java】 大话数据结构(14) 排序算法(1) (冒泡排序及其优化)
  18. stl学习记录(2)
  19. Java静态代码块
  20. Ios国际化翻译工具

热门文章

  1. 迅为4412嵌入式安卓开发板兼容3G网络|4G网络
  2. spring cloud 概念
  3. No-8.循环
  4. 亲测可用)html5 file调用手机摄像头
  5. MySQL和Oracle的比较
  6. Python之禅 吾心笃定
  7. Python之机器学习-朴素贝叶斯(垃圾邮件分类)
  8. linux下mysql的安装与使用
  9. build.plugins.plugin.version&#39; for org.apache.maven.plugins:maven-compiler-plugin is missing
  10. 【BZOJ 1202】 [HNOI2005]狡猾的商人 (加权并查集)