您当前的位置: 首页 > 技术文章 > 前端开发

ERROR in Conflict: Multiple assets emit different content to the same filename index.html

作者: 时间:2022-03-26阅读数:人阅读

前置期望:多入口起点,多个HTML,每个HTML配置一个入口起点

初始出错的webpack关键配置信息

module.exports = {
  mode: 'development',
  entry: {
    entry1: './src/entry1/index.ts',
    entry2: './src/entry2/index.ts'
  },
  output: {
    filename: '[name].bundle.js',
    chunkFilename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
    clean: true,
  },
  plugins: [
     new HtmlWebpackPlugin({
        title: 'entry1_HTML_FILE',
        inject: "body",
        template: "./src/entry1_sub_directory/entry1_template.html",
        chunks: ['entry1']
     }),
     new HtmlWebpackPlugin({
        title: 'entry2_HTML_FILE',
        inject: "body",
        template: "./src/entry2_sub_directory/entry2_template.html",
        chunks: ['entry2']
     })
  ],
   // BLOG Author: 埃里克森枫
   // ...其他webpack配置信息省略
}

执行打包命令后得到错误信息

ERROR in Conflict: Multiple assets emit different content to the same filename index.html

出错点是插件Html Webpack Plugin 使用了默认的filename(index.html)导致的

因此指定filename就能解决

参考官方文档修改filename

https://github.com/jantimon/html-webpack-plugin#options

filename {String|Function} 'index.html'

The file to write the HTML to. Defaults to index.html. You can specify a subdirectory here too (eg: assets/admin.html). The [name] placeholder will be replaced with the entry name. Can also be a function e.g. (entryName) => entryName + '.html'.

 修改后的webpack 配置文件:

module.exports = {
  mode: 'development',
  entry: {
    entry1: './src/entry1/index.ts',
    entry2: './src/entry2/index.ts'
  },
  output: {
    filename: '[name].bundle.js',
    chunkFilename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
    clean: true,
  },
  plugins: [
     new HtmlWebpackPlugin({
        title: 'entry1_HTML_FILE',
        inject: "body",
        filename: 'entry1.html', // 此处新增
        template: "./src/entry1_sub_directory/entry1_template.html",
        chunks: ['entry1']
     }),
     new HtmlWebpackPlugin({
        title: 'entry2_HTML_FILE',
        inject: "body",
        filename: 'entry2.html', // 此处新增
        template: "./src/entry2_sub_directory/entry2_template.html",
        chunks: ['entry2']
     })
  ],
   // BLOG Author: 埃里克森枫
   // ...其他webpack配置信息省略
}

 

本站所有文章、数据、图片均来自互联网,一切版权均归源网站或源作者所有。

如果侵犯了你的权益请来信告知我们删除。邮箱:licqi@yunshuaiweb.com

标签: webpack
加载中~
如果您对我们的成果表示认同并且觉得对你有所帮助可以给我们捐赠。您的帮助是对我们最大的支持和动力!
捐赠我们
扫码支持 扫码支持
扫码捐赠,你说多少就多少
2
5
10
20
50
自定义
您当前余额:元
支付宝
微信
余额

打开支付宝扫一扫,即可进行扫码捐赠哦

打开微信扫一扫,即可进行扫码捐赠哦

打开QQ钱包扫一扫,即可进行扫码捐赠哦