webpack 單獨(dú)打包指定JS文件的方法
背景
最近接到一個(gè)需求,因?yàn)椴淮_定打出的前端包所訪問(wèn)的后端IP,需要對(duì)項(xiàng)目中IP配置文件單獨(dú)拿出來(lái),方便運(yùn)維部署的時(shí)候?qū)P做修改。因此,需要用webpack單獨(dú)打包指定文件。
CommonsChunkPlugin
module.exports = { entry: { app: APP_FILE // 入口文件 }, output: { publicPath: './dist/', //輸出目錄,index.html尋找資源的地址 path: BUILD_PATH, // 打包目錄 filename: '[name].[chunkhash].js', // 輸出文件名 chunkFilename: '[name].[chunkhash].js' // commonChunk 輸出文件 } }
題外話
{
先說(shuō)一下publicPath , 這邊有一個(gè)注意的點(diǎn),即路徑寫(xiě)成 ./dist 相對(duì)路徑。如果寫(xiě)成/dist/這種絕對(duì)路徑,有一個(gè)弊端是當(dāng)nginx把前端的包沒(méi)有放在根目錄的情況下,index.html會(huì)訪問(wèn)資源失敗。因此推薦寫(xiě)成相對(duì)路徑,但是當(dāng)使用相對(duì)路徑時(shí),有會(huì)存在一個(gè)潛在的問(wèn)題,即項(xiàng)目本身的路由訪問(wèn)如果是HTML5模式,而不是使用hash時(shí)(路由上有一個(gè)#號(hào)),那么項(xiàng)目一樣會(huì)部署失敗。angular,react都會(huì)有這樣的問(wèn)題,vue沒(méi)用過(guò),應(yīng)該類似。此時(shí)的解決辦法是,在index.html的head中添加base標(biāo)簽,即:
<head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"/> <base href="/" rel="external nofollow" > </head>
}
webpack本身基于模塊化,因此大多數(shù)情況下,我們僅需要一個(gè)入口文件就可以搞定。而針對(duì)本次需求,需要在app,這個(gè)入口之外再添加一個(gè)入口文件。即:
entry: { app: APP_FILE // 入口文件 ip: IP_FILE },
僅這樣對(duì)webpack配置之后,dist文件會(huì)成功打出app.xxx.js及ip.xxx.js,但是打包出的項(xiàng)目還是會(huì)報(bào)錯(cuò),解決辦法是:維持IP的入口文件不變,但是把它當(dāng)作commonChunk來(lái)處理。即在plugins中加入:
new webpack.optimize.CommonsChunkPlugin({name: 'ip', minChunks: Infinity}),
這樣保證優(yōu)先加載ip.xxx.js,避免報(bào)錯(cuò)。
缺點(diǎn):這樣打包有一個(gè)很明顯的缺點(diǎn),即是打包出的文件是壓縮的,不方便對(duì)文件進(jìn)行二次修改。(沒(méi)有找到解決壓縮的辦法)
CopyWebpackPlugin
最終解決辦法,還是通過(guò)讓ip.js這個(gè)文件脫離項(xiàng)目的模塊化,然后在index.html中單獨(dú)引用。(這是最開(kāi)始就想到的解決辦法,但并不是自己想要的解決方案,但無(wú)奈認(rèn)知有限,沒(méi)有解決掉之前的問(wèn)題)。
解決流程:
首先在webpack引入CopyWebpackPlugin, 配置代碼:
new CopyWebpackPlugin([ {from: './src/config/ip.js', to: 'ip.js'}, ])
在index.html中單獨(dú)引入script標(biāo)簽,注意要配置一個(gè)隨機(jī)后綴,即:
<script> document.write("<s"+"cript type='text/javascript' src='./dist/ip.js?"+Math.random().toString(36).substr(2)+"'></scr"+"ipt>"); </script>
防止ip.js因?yàn)榫彺鎸?dǎo)致問(wèn)題。
以上,就解決了webpack單獨(dú)打包指定js的問(wèn)題。
ps:希望有更好的方法來(lái)分享給我。
這篇webpack 單獨(dú)打包指定JS文件的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 高仿真可控彈簧振子實(shí)現(xiàn)代碼
我剛學(xué)JavaScript ,看見(jiàn)一些牛人寫(xiě)了許多特效,我也花了一天寫(xiě)了一個(gè)彈簧振子,完全獨(dú)創(chuàng),沒(méi)有借鑒任何人的代碼.2009-10-10JS隨機(jī)排序數(shù)組實(shí)現(xiàn)方法分析
這篇文章主要介紹了JS隨機(jī)排序數(shù)組實(shí)現(xiàn)方法,結(jié)合具體實(shí)例形式對(duì)比分析了javascript針對(duì)數(shù)組進(jìn)行隨機(jī)排序的相關(guān)操作技巧,需要的朋友可以參考下2017-10-10js實(shí)現(xiàn)的鼠標(biāo)滾輪滾動(dòng)切換頁(yè)面效果(類似360默認(rèn)頁(yè)面滾動(dòng)切換效果)
這篇文章主要介紹了js實(shí)現(xiàn)的鼠標(biāo)滾輪滾動(dòng)切換頁(yè)面效果,類似360默認(rèn)頁(yè)面滾動(dòng)切換效果.涉及JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)變換頁(yè)面元素的相關(guān)技巧,需要的朋友可以參考下2016-01-01IntelliJ IDEA 安裝vue開(kāi)發(fā)插件的方法
本篇文章主要介紹了IntelliJ IDEA 安裝vue開(kāi)發(fā)插件的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11JavaScript垃圾回收機(jī)制(引用計(jì)數(shù),標(biāo)記清除,性能優(yōu)化)
這篇文章主要介紹了JavaScript垃圾回收機(jī)制(引用計(jì)數(shù),標(biāo)記清除,性能優(yōu)化),垃圾回收是JavaScript的隱藏機(jī)制,我們通常無(wú)需為垃圾回收勞心費(fèi)力,只需要專注功能的開(kāi)發(fā)就好了2022-07-07JS獲取html元素的標(biāo)記名實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇JS獲取html元素的標(biāo)記名實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10JS獲得多個(gè)同name 的input輸入框的值的實(shí)現(xiàn)方法
這篇文章主要介紹了基于JS代碼實(shí)現(xiàn)input密碼輸入框輸入密碼變黑點(diǎn)密文以及JS獲得多個(gè)同name 的input輸入框的值的實(shí)現(xiàn)方法,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-01-01