下面我就為大家分享一篇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>
entry: { app: APP_FILE // 入口文件 ip: IP_FILE },
new webpack.optimize.CommonsChunkPlugin({name: 'ip', minChunks: Infinity}),
CopyWebpackPlugin
最終解決方法,還是透過讓ip.js這個檔案脫離專案的模組化,然後在index.html中單獨引用。 (這是一開始就想到的解決辦法,但不是自己想要的解決方案,但無奈認知有限,沒有解決掉之前的問題)。 解決流程:首先在webpack引入CopyWebpackPlugin, 配置代碼:new CopyWebpackPlugin([ {from: './src/config/ip.js', to: 'ip.js'}, ])
<script> document.write("<s"+"cript type='text/javascript' src='./dist/ip.js?"+Math.random().toString(36).substr(2)+"'></scr"+"ipt>"); </script>
以上是在webpack中如何單獨打包指定JS文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!