美文网首页
Webpack4-Entry

Webpack4-Entry

作者: 16325 | 来源:发表于2020-03-07 23:33 被阅读0次

    入口起点(Entry Points)

    在 webpack 配置中有多种方式定义 entry 属性。

    单个入口(简写)语法

    用法:entry: string|Array<string>

    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”时,传入数组的方式就很有用。

    对象语法

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

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

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

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

    多入口

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

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

    为什么?在多页应用中,(译注:每当页面跳转时)服务器将为你获取一个新的 HTML 文档。页面重新加载新文档,并且资源被重新下载。然而,这给了我们特殊的机会去做很多事:

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

    相关文章

      网友评论

          本文标题:Webpack4-Entry

          本文链接:https://www.haomeiwen.com/subject/zfikdhtx.html