webpack对html文件的处理方法
这篇文章主要讲解了“webpack对html文件的处理方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“webpack对html文件的处理方法”吧!
为什么去处理html文件
我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个class="lazy" data-src引入这些dist文件夹下的js,那么也有些太不靠谱了
所以解决办法是:
使用webpack插件:HtmlWebpackPlugin
第一步:下载
npminstall--save-devextract-text-webpack-plugin
第二步:webpack.config.js配置
其中HtmlWebpackPlugin的配置项有:
Name 类型 Description
title {String} 用于生成的HTML文档的
filename {String} 要生成HTML的文件。可以指定目录
template {String} 依据的模板文件
inject {Boolean|String} 将js资源注入到页面哪个部位,值有:true\‘head’\‘body’\false,当传递true或’body’所有JavaScript资源将被放置在正文元素的底部。’head’将脚本放置在head元素中
favicon {String} 将给定的图标路径添加到输出HTML
hash {Boolean} 如果true将webpack所有包含的脚本和CSS文件附加一个独特的编译哈希。这对缓存清除非常有用
chunks {?} 放入你需要引入的资源模块
excludeChunks {?} 不放入你某些资源模块
预期目标:我的项目是一个多入口文件的项目,希望每一个入口页面引入对应的js模块和css
比如login页面引入login的js和css、index引入对应js和css
webpack.config.js配置如下:
constpath=require('path');constwebpack=require('webpack')constExtractTextPlugin=require("extract-text-webpack-plugin");constHtmlWebpackPlugin=require('html-webpack-plugin');constconfigs={
entry:{'commom':['./class="lazy" data-src/page/common/index.js'],'index':['./class="lazy" data-src/page/index/index.js'],'login':['./class="lazy" data-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:[//独立通用模块
newwebpack.optimize.CommonsChunkPlugin({
name:'common',
filename:'js/base.js'
}),//独立打包css
newExtractTextPlugin('css/[name].css'),//对html模板进行处理,生成对应的html,引入需要的资源模块
newHtmlWebpackPlugin({
template:'./class="lazy" data-src/view/index.html',//模板文件
filename:'view/login/index.html',//目标文件
chunks:['commom','login'],//对应加载的资源
inject:true,//资源加入到底部
hash:true//加入版本号
})
]
}
module.exports=configs
感谢各位的阅读,以上就是“webpack对html文件的处理方法”的内容了,经过本文的学习后,相信大家对webpack对html文件的处理方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341