国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

webpack 單獨(dú)打包指定JS文件的方法

2024-05-06 15:21:40
字體:
供稿:網(wǎng)友

背景

最近接到一個(gè)需求,因?yàn)椴淮_定打出的前端包所訪問的后端IP,需要對(duì)項(xiàng)目中IP配置文件單獨(dú)拿出來,方便運(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 輸出文件 }}

題外話

{

先說一下publicPath , 這邊有一個(gè)注意的點(diǎn),即路徑寫成 ./dist 相對(duì)路徑。如果寫成/dist/這種絕對(duì)路徑,有一個(gè)弊端是當(dāng)nginx把前端的包沒有放在根目錄的情況下,index.html會(huì)訪問資源失敗。因此推薦寫成相對(duì)路徑,但是當(dāng)使用相對(duì)路徑時(shí),有會(huì)存在一個(gè)潛在的問題,即項(xiàng)目本身的路由訪問如果是HTML5模式,而不是使用hash時(shí)(路由上有一個(gè)#號(hào)),那么項(xiàng)目一樣會(huì)部署失敗。angular,react都會(huì)有這樣的問題,vue沒用過,應(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來處理。即在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)行二次修改。(沒有找到解決壓縮的辦法)

CopyWebpackPlugin

最終解決辦法,還是通過讓ip.js這個(gè)文件脫離項(xiàng)目的模塊化,然后在index.html中單獨(dú)引用。(這是最開始就想到的解決辦法,但并不是自己想要的解決方案,但無奈認(rè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>            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 鹿邑县| 竹溪县| 平潭县| 阿图什市| 明星| 从化市| 余江县| 广宗县| 渝中区| 盖州市| 淅川县| 从江县| 鄯善县| 手游| 长宁县| 疏勒县| 托克托县| 静乐县| 遂宁市| 星子县| 栖霞市| 望都县| 九江市| 桃园县| 永安市| 华容县| 澄城县| 日土县| 政和县| 酉阳| 体育| 忻城县| 襄城县| 通山县| 封丘县| 英吉沙县| 武乡县| 安徽省| 唐河县| 莱西市| 桐城市|