欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

webpack如何單獨(dú)打包指定JS文件-創(chuàng)新互聯(lián)

這篇文章主要介紹了webpack如何單獨(dú)打包指定JS文件,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)是一家專注于做網(wǎng)站、成都做網(wǎng)站與策劃設(shè)計(jì),九原網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:九原等地區(qū)。九原做網(wǎng)站價格咨詢:13518219792

背景

最近接到一個需求,因?yàn)椴淮_定打出的前端包所訪問的后端IP,需要對項(xiàng)目中IP配置文件單獨(dú)拿出來,方便運(yùn)維部署的時候?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 , 這邊有一個注意的點(diǎn),即路徑寫成 ./dist 相對路徑。如果寫成/dist/這種絕對路徑,有一個弊端是當(dāng)nginx把前端的包沒有放在根目錄的情況下,index.html會訪問資源失敗。因此推薦寫成相對路徑,但是當(dāng)使用相對路徑時,有會存在一個潛在的問題,即項(xiàng)目本身的路由訪問如果是HTML5模式,而不是使用hash時(路由上有一個#號),那么項(xiàng)目一樣會部署失敗。angular,react都會有這樣的問題,vue沒用過,應(yīng)該類似。此時的解決辦法是,在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ù)情況下,我們僅需要一個入口文件就可以搞定。而針對本次需求,需要在app,這個入口之外再添加一個入口文件。即:

 entry: {
 app: APP_FILE // 入口文件
 ip: IP_FILE
 },

僅這樣對webpack配置之后,dist文件會成功打出app.xxx.js及ip.xxx.js,但是打包出的項(xiàng)目還是會報錯,解決辦法是:維持IP的入口文件不變,但是把它當(dāng)作commonChunk來處理。即在plugins中加入:

new webpack.optimize.CommonsChunkPlugin({name: 'ip', minChunks: Infinity}),

這樣保證優(yōu)先加載ip.xxx.js,避免報錯。

缺點(diǎn):這樣打包有一個很明顯的缺點(diǎn),即是打包出的文件是壓縮的,不方便對文件進(jìn)行二次修改。(沒有找到解決壓縮的辦法)

CopyWebpackPlugin

最終解決辦法,還是通過讓ip.js這個文件脫離項(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)簽,注意要配置一個隨機(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)致問題。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“webpack如何單獨(dú)打包指定JS文件”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計(jì)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)站欄目:webpack如何單獨(dú)打包指定JS文件-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://chinadenli.net/article28/dhpsjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、小程序開發(fā)手機(jī)網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化網(wǎng)站內(nèi)鏈、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)