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="/"> </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的問題。

 

webpack---webpack中經典實用的插件copy-webpack-plugin拷貝資源插件

在webpack中拷貝文件和文件夾

cnpm install --save-dev copy-webpack-plugin
new CopyWebpackPlugin([{ from: __dirname + '/src/public' }]); //作用:把public 里面的內容全部拷貝到編譯目錄

 

from 定義要拷貝的源目錄 from: __dirname + ‘/src/public’ to 定義要拷貝到的目標目錄 from: __dirname + ‘/dist’ toType file 或者 dir 可選,默認是文件 force 強制覆蓋先前的插件 可選 默認false context 可選 默認base context可用specific context flatten 只拷貝文件不管文件夾 默認是false ignore 忽略拷貝指定的文件 可以用模糊匹配

原文:https://blog.csdn.net/qq_44163269/article/details/106668415


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM