作用
直接为项目生成一个或多个HTML文件(HTML文件个数由插件实例的个数决定),并将webpack打包后输出的所有脚本文件自动添加到插件生成的HTML文件中。通过配置,可以将根目录下用户自定义的HTML文件作为插件生成HTML文件的模板。另外,还可以通过向插件传递参数,控制HTML文件的输出。
用法:
-
第一步:在项目根目录下安装插件:
cnpm install html-webpack-plugin --save-dev
-
第二步:在webpack配置文件头部require html-webpack-plugin模块,并保存引用至htmlWebpackPlugin变量。
var htmlWebpackPlugin = require('html-webpack-plugin');
-
第三步:为webpack配置文件暴露的对象添加一个plugins属性,属性值为一个数组,将新建的html-webpack-plugin对象实例添加到数组中。若不传入任何参数,那么插件将生成默认的html文件。
module.exports = { entry: { main:'./src/script/main.js' }, output: { path: './dist', filename: 'js/[name].bundle.js' }, plugins:[ new htmlWebpackPlugin() ] }
-
第四步:配置参数。为新建的对象实例传入一个对象字面量参数,初始化对象实例的属性。
module.exports = { ... , plugins:[ new htmlWebpackPlugin({ filename:'index.html', template:'template.html', inject:false, title:'webpack is good', chunks:['main'] }) ] }
htmlWebpackPlugin对象
htmlWebpackPlugin对象有两个属性,一个是files,一个是options。files和options的属性值都是对象。通过EJS语法,可以在HTML模板文件(template.html)中遍历这两个属性,查看其详情:
<% for(var key in htmlWebpackPlugin.files) { %> <%= key %> : <%= JSON.stringify(htmlWebpackPlugin.files[key]) %> //将对象或数组转换为JSON字符串。 <% } %> <% for(var key in htmlWebpackPlugin.options) { %> <%= key %> : <%= JSON.stringify(htmlWebpackPlugin.options[key]) %> <% } %>
遍历后的结果如下:
"htmlWebpackPlugin": { "files": { publicPath : "", "css": [], "js": [ "js/main.ae8647e767cd76e54693.bundle.js"], "chunks": { "main": { "size":23, "entry": "js/main.ae8647e767cd76e54693.bundle.js", "css": [], "hash":"ae8647e767cd76e54693", } }, manifest : "" }, "options":{ template : "C:\\dev\\webpack-demo\\node_modules\\.2.28.0@html-webpack-plugin\\lib\\loader.js!c:\\dev\\webpack-demo\\index.html", filename : "index.html", hash : false, inject : false, compile : true, favicon : false, minify : false, cache : true, showErrors : true, chunks : ["main"], excludeChunks : [], title : "webpack is good", xhtml : false } }
参数说明:
title: title值用于生成的HTML文档。
filename: 将生成的HTML写入到该文件中。默认写入到index.html中。你也可以在这儿指定子目录 (eg: assets/admin.html)。
template: Webpack require path 到 template中。 详情查阅 docs
inject:
true | 'head' | 'body' | false
添加所有的静态资源(assets)到模板文件或templateContent 。当传入true
或'body'
时,所有javascript资源将被放置到body 元素的底部。 当传入'head'
时, 所有的脚本将被放置到head元素中。favicon: 添加指定的favicon path到输出的html文件。
minify:
{...} | false
传入一个html-minifier 对象选项来压缩输出的html文件。hash:
true | false
如果值为true,就添加一个唯一的webpack compilation hash给所有已included的 scripts 和 CSS 文件。这对缓存清除(cache busting)十分有用。cache:
true | false
如果为true (默认),只要文件被更改了就emit(发表)文件。showErrors:
true | false
如果为true (默认),详细的错误信息将被写入到HTML页面。chunks:允许你只添加某些chunks (e.g. only the unit-test chunk)
chunksSortMode: 在chunks被include到html文件中以前,允许你控制chunks 应当如何被排序。允许的值:
'none' | 'auto' | 'dependency' | {function}
- 默认值:'auto'
。excludeChunks: 允许你跳过某些chunks (e.g. don't add the unit-test chunk)
xhtml:
true | false
如果为true, 将 link 标签渲染为自闭合标签, XHTML compliant。 默认是 false。
template参数
由于html-webpack-plugin直接生成的HTML文件十分简单,不能满足项目需求,因此我们通常会配置template参数,将该参数值设置为我们已创建好的HMTL模板文件相对于根目录的相对路径。
template:'template.html'
由于html-webpack-plugin支持EJS模板语法,因此在模板文件中,我们可以使用EJS模板语法来获取htmlWebpackPlugin对象中的数据,以此来控制html的输出。
chunks或excludeChunks参数
chunks或excludeChunks参数限定了HTML模板文件中能够包含的打包后的脚本文件。该参数对脚本的自动注入或手动注入都有限定作用。
inject参数
注意下面两种情况:
-
若inject值为false,那么所有打包后的脚本文件都不会被自动添加到HTML模板文件中。此时你需要在模板文件中通过EJS语法,在需要的位置处,手动添加相应的脚本文件,若不添加,打包后的脚本文件将不会出现在HTML模板文件相应的位置上。
module.exports = { ... plugins:[ new htmlWebpackPlugin({ filename:'c.html', template:'index.html', title:'this is c.html', inject:false, excludeChunks:['a','b'] }) ] }
-
若inject未设置,或设置了非false的值,那么所有打包后的脚本文件都会被自动添加到HTML模板文件中。在这种场景下,HTML模板文件中不能出现任何手动添加的打包后的脚本文件。因为后者会导致webpack报错或是出现脚本重复注入的情况。
module.exports = { ... plugins:[ new htmlWebpackPlugin({ filename:'admin.html', template:'index.html', inject:'head', chunks:['a','b','c'] }) ] }
当inject未设置,或设置了非false的值时:若此时HTML模板文件中已有被手动添加的打包后的脚本文件,那么:
当该脚本文件所对应的chunk与chunks或excludeChunks参数所限定的chunk不一致时,webpack会报错;
当手动添加的位置与inject参数值所指示的位置不一致时,webpack也会报错。
若都一致,那么手动添加的脚本文件也会被注入到HTML模板中,从而出现脚本重复注入的情况。
结论:在同一HTML模板文件中,自动添加已打包的脚本文件与手动添加已打包的脚本文件不能并存,这两项操作只能选其一。
特殊情况:使用EJS语法向HTML模板文件手动添加打包后的脚本文件:
1.由于inject参数不能被同时设置为'head'和'body',因此,当有的打包后的脚本文件需要被添加到head标签,而另外的需要被添加到body标签中时,就需要手动向HTML模板注入脚本。
<head> ... <script src="<%= htmlWebpackPlugin.files.chunks.main.entry %>"></script> </head> <body> <% for(var k in htmlWebpackPlugin.files.chunks){ %> <% if(k!=='main'){ %> <script src="<%= htmlWebpackPlugin.files.chunks[k].entry %>"></script> <% } %> <% } %> </body>
2.为了网页的加载性能,减少HTTP请求数,当有的打包后的脚本文件需要被内嵌到head标签中,而其余的需要以引用外部资源的方式添加到HTML模板中时,也需要手动向HTML模板注入脚本。
<head> ... <script type="text/javascript" src="<%= compilation.assets[htmlWebpackPlugin.files.chunks.main.entry.substr(htmlWebpackPlugin.files.publicPath.length)].source() %>"></script> </head> <body> <% for(var k in htmlWebpackPlugin.files.chunks){ %> <% if(k!=='main'){ %> <script src="<%= htmlWebpackPlugin.files.chunks[k].entry %>"></script> <% } %> <% } %> </body>
生成多个HTML文件
如果我们开发的是一个多页面应用程序,那么我们就需要为不同的页面生成不同的HTML文件。通过向plugins数组添加多个插件实例就可以实现:
module.exports = { entry: 'index.js', output: { path: 'dist', filename: 'index_bundle.js' }, plugins: [ new HtmlWebpackPlugin(), // Generates default index.html new HtmlWebpackPlugin({ // Also generate a test.html filename: 'test.html', template: 'src/assets/test.html' }) ] }
以上是html-webpack-plugin的程式碼分析詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

HTML的未來將朝著更加語義化、功能化和模塊化的方向發展。 1)語義化將使標籤更明確地描述內容,提升SEO和無障礙訪問。 2)功能化將引入新元素和屬性,滿足用戶需求。 3)模塊化將支持組件化開發,提高代碼復用性。

htmlattributesarecrucialinwebdevelopment forcontrollingBehavior,外觀和功能

alt屬性是HTML中標籤的重要部分,用於提供圖片的替代文本。 1.當圖片無法加載時,alt屬性中的文本會顯示,提升用戶體驗。 2.屏幕閱讀器使用alt屬性幫助視障用戶理解圖片內容。 3.搜索引擎索引alt屬性中的文本,提高網頁的SEO排名。

HTML、CSS和JavaScript在網頁開發中的作用分別是:1.HTML用於構建網頁結構;2.CSS用於美化網頁外觀;3.JavaScript用於實現動態交互。通過標籤、樣式和腳本,這三者共同構築了現代網頁的核心功能。

設置標籤的lang屬性是優化網頁可訪問性和SEO的關鍵步驟。 1)在標籤中設置lang屬性,如。 2)在多語言內容中,為不同語言部分設置lang屬性,如。 3)使用符合ISO639-1標準的語言代碼,如"en"、"fr"、"zh"等。正確設置lang屬性可以提高網頁的可訪問性和搜索引擎排名。

htmlattributeseresene forenhancingwebelements'functionalityandAppearance.TheyAdDinformationTodeFineBehavior,外觀和互動,使網站互動,響應式,visalalyAppealing.AttributesLikutesLikeSlikEslikesrc,href,href,href,類,類型,類型,和dissabledtransfransformformformformformformformformformformformformformformforment

toCreateAlistInHtml,useforforunordedlistsandfororderedlists:1)forunorderedlists,wrapitemsinanduseforeachItem,RenderingeringAsabulletedList.2)fororderedlists,useandfornumberedlists,useandfornumberedlists,casundfornumberedlists,casundfornthetthetthetthetthetthetthetttributefordforderfordforderforderentnumberingsnumberingsnumberingStys。

HTML用於構建結構清晰的網站。 1)使用標籤如、、定義網站結構。 2)示例展示了博客和電商網站的結構。 3)避免常見錯誤如標籤嵌套不正確。 4)優化性能通過減少HTTP請求和使用語義化標籤。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載
最受歡迎的的開源編輯器