javascript - webpack 多入口配置問題, 打包出來的結果變成每個html引用了所有打包的js文件
黄舟
黄舟 2017-06-30 09:55:12
0
2
781

如題
該怎麼配置才能讓html掛載對應的js檔呢。
因為文件帶hash,沒辦法用htmlWebpackPlugin來寫死,或是有什麼寫法可以解決這個問題?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回覆(2)
迷茫

可不可以在plugins中定義多個HtmlWebpackPlugin, 每個Plugin中指定對應的Chunk,如下

module.exports = {
  entry: {
    'page1': './apps/page1/scripts/main.js',
    'page2': './apps/page2/src/main.js'
  },
  output: {
    path: __dirname,
    filename: "apps/[name]/build/bundle.js"
  },
  plugins: [
    new HtmlWebpackPlugin({
      inject: false,
      chunks: ['page1'],
      filename: 'apps/page1/build/index.html'
    }),
    new HtmlWebpackPlugin({
      inject: false,
      chunks: ['page2'],
      filename: 'apps/page2/build/index.html'
    })
  ]
};
大家讲道理

樓上的做一些修改

var getHtmlConfig = function(name){
    return {
        template    : './src/view/' + name + '.html',
        filename    : 'view/' + name + '.html',
        inject      : true,
        hash        : true,
        chunks      : ['common', name]
    };
};
plugins: [
    new HtmlWebpackPlugin( getHtmlConfig(name1)),
    new HtmlWebpackPlugin( getHtmlConfig(name2)),
    new HtmlWebpackPlugin( getHtmlConfig(name3))
]

output: {
    path: './dist',
    publicPath : '/dist',
    filename: 'js/[name].js'
},

你把原來的檔案放在src/view下面...
生產的檔案會放在dist/'view/' + name + '.html'

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板