首页 > 编程 > HTML > 正文

webpack对html文件的处理

2020-03-24 17:39:02
字体:
来源:转载
供稿:网友

本篇文章给大家分享的是关于webpack对html文件的处理 ,步骤都很详细,有需要的朋友可以参考一下

为什么去处理html文件
我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个src引入这些dist文件夹下的js,那么也有些太不靠谱了

所以解决办法是:

使用webpack插件:HtmlWebpackPlugin

第一步:下载

npm install --save-dev extract-text-webpack-plugin

第二步:webpack.config.js配置

其中HtmlWebpackPlugin的配置项有:

Name类型Descriptiontitle{String}用于生成的HTML文档的标题filename{String}要生成HTML的文件。可以指定目录template{String}依据的模板文件inject{Boolean|String}将js资源注入到页面哪个部位,值有:true / ‘head’ / ‘body’ / false,当传递true或’body’所有JavaScript资源将被放置在正文元素的底部。’head’将脚本放置在head元素中favicon{String}将给定的图标路径添加到输出HTMLhash{Boolean}如果true将webpack所有包含的脚本和CSS文件附加一个独特的编译哈希。这对缓存清除非常有用chunks{?}放入你需要引入的资源模块excludeChunks{?}不放入你某些资源模块

预期目标: 我的项目是一个多入口文件的项目,希望每一个入口页面引入对应的js模块和css
比如login页面引入login的js和css、index引入对应js和css

webpack.config.js配置如下:

const path = require( path const webpack = require( webpack )const ExtractTextPlugin = require( extract-text-webpack-plugin const HtmlWebpackPlugin = require( html-webpack-plugin const configs = { entry:{ commom :[ ./src/page/common/index.js ], index :[ ./src/page/index/index.js ], login :[ ./src/page/login/index.js ] output:{ path:path.resolve(__dirname, dist ), filename: js/[name].js  module:{ rules:[ test://.css$/, use:ExtractTextPlugin.extract({ fallback: style-loader , use: css-loader  plugins:[ //独立通用模块 new webpack.optimize.CommonsChunkPlugin({ name : common , filename : js/base.js  }), //独立打包css new ExtractTextPlugin( css/[name].css ), //对html模板进行处理,生成对应的html,引入需要的资源模块 new HtmlWebpackPlugin({ template: ./src/view/index.html ,//模板文件 filename: view/login/index.html ,//目标文件 chunks:[ commom , login ],//对应加载的资源 inject:true,//资源加入到底部 hash:true//加入版本号module.exports= configs

然后打包结果如下
这里写图片描述

其中生成的目标文件:
这里写图片描述

为什么去处理html文件
我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个src引入这些dist文件夹下的js,那么也有些太不靠谱了

所以解决办法是:

使用webpack插件:HtmlWebpackPlugin

第一步:下载

npm install --save-dev extract-text-webpack-plugin

第二步:webpack.config.js配置

其中HtmlWebpackPlugin的配置项有:

Name类型Descriptiontitle{String}用于生成的HTML文档的标题filename{String}要生成HTML的文件。可以指定目录template{String}依据的模板文件inject{Boolean|String}将js资源注入到页面哪个部位,值有:true / ‘head’ / ‘body’ / false,当传递true或’body’所有JavaScript资源将被放置在正文元素的底部。’head’将脚本放置在head元素中favicon{String}将给定的图标路径添加到输出HTMLhash{Boolean}如果true将webpack所有包含的脚本和CSS文件附加一个独特的编译哈希。这对缓存清除非常有用chunks{?}放入你需要引入的资源模块excludeChunks{?}不放入你某些资源模块

预期目标: 我的项目是一个多入口文件的项目,希望每一个入口页面引入对应的js模块和css
比如login页面引入login的js和css、index引入对应js和css

webpack.config.js配置如下:

const path = require( path const webpack = require( webpack )const ExtractTextPlugin = require( extract-text-webpack-plugin const HtmlWebpackPlugin = require( html-webpack-plugin const configs = { entry:{ commom :[ ./src/page/common/index.js ], index :[ ./src/page/index/index.js ], login :[ ./src/page/login/index.js ] output:{ path:path.resolve(__dirname, dist ), filename: js/[name].js  module:{ rules:[ test://.css$/, use:ExtractTextPlugin.extract({ fallback: style-loader , use: css-loader  plugins:[ //独立通用模块 new webpack.optimize.CommonsChunkPlugin({ name : common , filename : js/base.js  }), //独立打包css new ExtractTextPlugin( css/[name].css ), //对html模板进行处理,生成对应的html,引入需要的资源模块 new HtmlWebpackPlugin({ template: ./src/view/index.html ,//模板文件 filename: view/login/index.html ,//目标文件 chunks:[ commom , login ],//对应加载的资源 inject:true,//资源加入到底部 hash:true//加入版本号module.exports= configs

然后打包结果如下
这里写图片描述

其中生成的目标文件:
这里写图片描述

相关推荐:

在webpack中使用ECharts详解

Node.js、jade生成静态html文件实例

webpack的插件详解

以上就是webpack对html文件的处理的详细内容,html教程

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表