中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

webpack如何單獨打包指定JS文件

發布時間:2021-08-13 08:51:07 來源:億速云 閱讀:376 作者:小新 欄目:web開發

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

背景

最近接到一個需求,因為不確定打出的前端包所訪問的后端IP,需要對項目中IP配置文件單獨拿出來,方便運維部署的時候對IP做修改。因此,需要用webpack單獨打包指定文件。

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 , 這邊有一個注意的點,即路徑寫成 ./dist 相對路徑。如果寫成/dist/這種絕對路徑,有一個弊端是當nginx把前端的包沒有放在根目錄的情況下,index.html會訪問資源失敗。因此推薦寫成相對路徑,但是當使用相對路徑時,有會存在一個潛在的問題,即項目本身的路由訪問如果是HTML5模式,而不是使用hash時(路由上有一個#號),那么項目一樣會部署失敗。angular,react都會有這樣的問題,vue沒用過,應該類似。此時的解決辦法是,在index.html的head中添加base標簽,即:

<head>
 <meta charset="utf-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
 <base href="/" rel="external nofollow" >
</head>

}

webpack本身基于模塊化,因此大多數情況下,我們僅需要一個入口文件就可以搞定。而針對本次需求,需要在app,這個入口之外再添加一個入口文件。即:

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

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

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

這樣保證優先加載ip.xxx.js,避免報錯。

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

CopyWebpackPlugin

最終解決辦法,還是通過讓ip.js這個文件脫離項目的模塊化,然后在index.html中單獨引用。(這是最開始就想到的解決辦法,但并不是自己想要的解決方案,但無奈認知有限,沒有解決掉之前的問題)。

解決流程:

首先在webpack引入CopyWebpackPlugin, 配置代碼:

new CopyWebpackPlugin([
  {from: './src/config/ip.js', to: 'ip.js'},
 ])

在index.html中單獨引入script標簽,注意要配置一個隨機后綴,即:

<script>
 document.write("<s"+"cript type='text/javascript' src='./dist/ip.js?"+Math.random().toString(36).substr(2)+"'></scr"+"ipt>");
</script>

防止ip.js因為緩存導致問題。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“webpack如何單獨打包指定JS文件”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南投市| 唐山市| 眉山市| 清流县| 平昌县| 崇左市| 天全县| 揭西县| 全南县| 南汇区| 三江| 淮阳县| 平遥县| 绥德县| 彭山县| 平阳县| 轮台县| 兰考县| 洛浦县| 梅河口市| 彩票| 南昌市| 巴塘县| 广宗县| 青岛市| 沅江市| 洛南县| 神池县| 东丰县| 新化县| 德州市| 宁都县| 济源市| 泰来县| 阿巴嘎旗| 平阳县| 牡丹江市| 西盟| 曲松县| 永定县| 台中县|