首頁  >  文章  >  web前端  >  webpack打包指定JS檔案需要怎麼做

webpack打包指定JS檔案需要怎麼做

php中世界最好的语言
php中世界最好的语言原創
2018-03-17 15:25:231698瀏覽

這次帶給大家webpack打包指定JS檔案要怎麼做,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=&#39;text/javascript&#39; src=&#39;./dist/ip.js?"+Math.random().toString(36).substr(2)+"&#39;></scr"+"ipt>");
</script>

防止ip.js因為快取導致問題。 以上,就解決了webpack單獨包裝指定js的問題。

ps:希望有更好的方法可以分享給我。

這篇webpack 單獨打包指定JS檔案的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

###相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章! ######推薦閱讀:#########JS實作預設頭像填號###############babel的使用詳解######## #######Webpack dev server熱載入無效怎麼處理#########

以上是webpack打包指定JS檔案需要怎麼做的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn