摘要:生成多頁面修改配置自動插入標(biāo)題第二個頁面打包并查看文件夾結(jié)構(gòu)這是一個模板文件這是一個模板文件此時的配置自動插入標(biāo)題第二個頁面其他配置看這里資源源代碼
0x001 概述
上一章之后已經(jīng)可以自動刷新瀏覽器了,大大方便了我們的開發(fā),這章開始講插件,第一個插件將會解決上一章節(jié)的一個問題,那就是index.html需要手動插入打包好的js,同時不會將index.html一起放到dist文件夾下的問題。
0x002 初始化項目創(chuàng)建項目文件夾0x003-html-webpack-plugin,我們將在這個文件夾底下開始這一章節(jié)的所有編碼
復(fù)制上一章的文件及其目錄,除了dist和index.html
+ webpack-study + 0x001-begin + 0x002-dev-server + 0x003-html-webpack-plugin + src - index.js - package.json - webpack.config.js0x003 簡單配置html-webpack-plugin并使用
安裝
# 終端輸入 $ cnpm install --save-dev html-webpack-plugin # 輸出 ? Installed 3 packages ... ? All packages installed (473 packages installed from npm registry, used 7s, speed 1.08MB/s, json 434(768.7kB), tarball 7.09MB)
配置
初始化插件
var HtmlWebpackPlugin = require("html-webpack-plugin");
添加插件
plugins : [ new HtmlWebpackPlugin() ]
最終配置文件
var path = require("path") var HtmlWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry : "./src/index.js", output : { path : path.resolve(__dirname, "dist"), filename: "index.js" }, devServer: { contentBase: path.resolve(__dirname, ""), port : 9000, compress : true, open : true, host : "0.0.0.0", index : "index.html" }, plugins : [ new HtmlWebpackPlugin() ] }
打包
$ npm run build Hash: 1d3993547a22839c5053 Version: webpack 3.8.1 Time: 413ms Asset Size Chunks Chunk Names index.js 510 bytes 0 [emitted] main index.html 181 bytes [emitted] [0] ./src/index.js 32 bytes {0} [built] Child html-webpack-plugin for "index.html": 1 asset [2] (webpack)/buildin/global.js 488 bytes {0} [built] [2] (webpack)/buildin/module.js 495 bytes {0} [built] + 2 hidden modules
此時查看dist,會發(fā)現(xiàn)生成了兩個文件
index.js:webpack打包生成的js文件
index.html:htmlWebpackPlugin自動生成
觀察index.html可以發(fā)現(xiàn),htmlWebpackPlugin不只是生成了一個html文件,還添加了對我們打包生成的index.js的引用。
0x004 插件配置Webpack App
自定義title
添加配置
// package.json new HtmlWebpackPlugin({ title: "自動插入標(biāo)題" })
打包
自動插入標(biāo)題
自定義文件名
添加配置
new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename: "admin.html", })
打包查看文件
+ dist - admin.html - index.js
根據(jù)模板生成
添加模板文件./index.html
這是一個模板文件
添加配置
new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename: "admin.html", template : path.resolve(__dirname, "index.html") })
打包
這是一個模板文件
自定義js文件注入位置
添加配置
new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename: "admin.html", template : path.resolve(__dirname, "index.html"), inject : "head" })
打包
這是一個模板文件
可配置的值:
true:注入
false:不注入
"head":注入頭部
"body":注入body底部
壓縮html
添加配置
new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename : "admin.html", template : path.resolve(__dirname, "index.html"), inject : "head", minify:{ collapseWhitespace:true, } }),
打包
這是一個模板文件
可選配置
這里的值是一個對象,具體可以配置哪些可以看html-minifier的配置說明
多入口的情況下自定義插入的chunk
添加入口文件index2.js、index3.js
// ./src/index2.js document.write("hello index2") // ./src/index3.js document.write("hello index3")
修改entry、output、plugin
var path = require("path") var HtmlWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry : { index1: "./src/index.js", index2: "./src/index2.js", index3: "./src/index3.js", }, output : { path : path.resolve(__dirname, "dist"), filename: "[name].[chunkhash].js" }, devServer: { contentBase: path.resolve(__dirname, ""), port : 9000, compress : true, open : true, host : "0.0.0.0", index : "index.html" }, plugins : [ new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename: "admin.html", template: path.resolve(__dirname, "index.html"), inject : "head", chunks : ["index", "index3"] }) ] }
打包
這是一個模板文件
注意:注入的順序和chunks的順序相反
自定義注入chunk的順序
修改配置
new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename : "admin.html", template : path.resolve(__dirname, "index.html"), inject : "head", chunks : ["index1", "index3"], chunksSortMode: function (chunk1, chunk2) { return -1; } })
打包
這是一個模板文件
可選值
none:不排序
"auto":根據(jù)thunk的id排序
"dependency":根據(jù)依賴排序
"manual":找不到文檔啊,不知道說的是啥
function:提供一個函數(shù)計算排序方式,會自動調(diào)用這個函數(shù)來計算排序,可以根據(jù)chunk1.names[0]和chunk2.names[0]對比計算出來,如果返回大于1的數(shù),則chunk1在前,chunk2在后,反之亦然。調(diào)試的時候可以直接在函數(shù)中console.log(chunk1, chunk2)來調(diào)試。
生成多頁面
修改配置
plugins : [ new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename : "admin.html", template : path.resolve(__dirname, "index.html"), inject : "head", chunks : ["index1", "index3"], chunksSortMode: function (chunk1, chunk2) { return 1; } }), new HtmlWebpackPlugin({ title : "第二個頁面", filename : "index.html", template : path.resolve(__dirname, "index.html"), inject : "head", chunks : ["index1", "index2"], chunksSortMode: function (chunk1, chunk2) { return 1; } }) ]
打包并查看dist
# dist 文件夾結(jié)構(gòu) + dist - index.html - admin.html - ...這是一個模板文件
這是一個模板文件
此時的配置
// webpack.config.js var path = require("path") var HtmlWebpackPlugin = require("html-webpack-plugin"); module.exports = { entry : { index1: "./src/index.js", index2: "./src/index2.js", index3: "./src/index3.js", }, output : { path : path.resolve(__dirname, "dist"), filename: "[name].[chunkhash].js" }, devServer: { contentBase: path.resolve(__dirname, ""), port : 9000, compress : true, open : true, host : "0.0.0.0", index : "index.html" }, plugins : [ new HtmlWebpackPlugin({ title : "自動插入標(biāo)題", filename : "admin.html", template : path.resolve(__dirname, "index.html"), inject : "head", minify:{ collapseWhitespace:true, }, chunks : ["index1", "index3"], chunksSortMode: function (chunk1, chunk2) { return 1; } }), new HtmlWebpackPlugin({ title : "第二個頁面", filename : "index.html", template : path.resolve(__dirname, "index.html"), inject : "head", minify:{ collapseWhitespace:true, }, chunks : ["index1", "index2"], chunksSortMode: function (chunk1, chunk2) { return 1; }, }) ] }
其他配置看這里
0x005 資源源代碼
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89533.html
摘要:概述上一章講的時候關(guān)于文件相關(guān)的,這一章講的是模板相關(guān)的。環(huán)境配置栗子加載安裝依賴包編寫并引入配置低于否則使用打包并查看結(jié)果可以看到,被打包成了字符串,并封裝成模塊導(dǎo)出。更多資源,請查閱的倉庫和官網(wǎng)資源源代碼 0x001 概述 上一章講的時候關(guān)于文件相關(guān)的loder,這一章講的是模板相關(guān)的loder。 0x002 環(huán)境配置 $ mkdir 0x010-templating-loader...
摘要:同時不能直接單純的指定輸出的文件名稱,比如,將會報錯,可以換成以下方式指定,或者其他類似方式。如果打包過程出現(xiàn)錯誤,比如語法錯誤,將會在控制臺以紅色文字顯示,并且在你修復(fù)之后會再次打包。 0x001 概述 其實我不知道怎么寫,所以決定就一塊一塊的寫點平常配置的過程,根據(jù)不同東西稍微分區(qū)一下就好了 0x002 初始化項目結(jié)構(gòu) $ mkdir webpack_study $ cd webp...
0x001 概述 上一章講的是裝載模板,這一章講的是裝載樣式 0x002 配置環(huán)境 $ mkdir 0x011-styling-loader $ cd 0x011-styling-loader $ npm init -y $ npm install --save-dev webpack $ touch ./src/index.js $ vim webpack.config.js // ./web...
摘要:概述上一章講了關(guān)于生成模板的,并且最后將壓縮,這一章講的是壓縮混淆配置環(huán)境初始化項目新建修改配置安裝依賴修改初始化添加插件最終配置文件打包配置匹配上的文件才壓縮添加修改打包未被壓縮壓縮了取值正則匹配或者正則匹配數(shù)組需要壓 0x001 概述 上一章講了關(guān)于生成模板html的,并且最后將html壓縮,這一章講的是js壓縮混淆 0x002 配置環(huán)境 初始化項目 $ npm init -y...
摘要:概述上一章已經(jīng)實現(xiàn)了最簡單的配置文件使用和監(jiān)聽功能,這一章要開始實現(xiàn)自動刷新。只能在終端中使用的在章節(jié)中指令后標(biāo)有可以使用的功能,快速調(diào)用終端最終項目文件夾結(jié)構(gòu)資源源代碼 0x001 概述 上一章已經(jīng)實現(xiàn)了最簡單的webpack配置文件使用和webpack監(jiān)聽功能,這一章要開始實現(xiàn)自動刷新。 0x002 瀏覽器自動刷新 創(chuàng)建新的項目框架 - webpack_study + ...
閱讀 1443·2021-09-03 10:29
閱讀 3469·2019-08-29 16:24
閱讀 2033·2019-08-29 11:03
閱讀 1421·2019-08-26 13:52
閱讀 2934·2019-08-26 11:36
閱讀 2797·2019-08-23 17:19
閱讀 569·2019-08-23 17:14
閱讀 817·2019-08-23 13:59