在vue-cli中如何將所有js以及css打包成一個js文件,如果做不到,如何將app.js manifest.js vendor.js打包成一個文件
這樣的需求不是很合理啊。具體參考樓上回答。
但非要實現(xiàn)也可以。
1、再怎么樣,我也建議提取css建議。不然等待JS加載完,才顯示樣式。用戶明顯可以看出樣式缺失,然后才有樣式。
提取使用的插件是用的extract-text-webpack-plugin。
2、從vue-cli @2.9.x版本的build/webpack.prod.conf.js 來看,會提取公共的JS代碼到mainfest.js,vendor.js,vendor-async.js。如果不需要就注釋即可。
剛好之前寫了篇分析vue-cli構建的文章,分析vue-cli@2.9.3 搭建的webpack項目工程,附上一些代碼和注釋可供參考。
// 提取公共代碼
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
minChunks (module) {
// any required modules inside node_modules are extracted to vendor
return (
module.resource &&
/\.js$/.test(module.resource) &&
module.resource.indexOf(
path.join(__dirname, '../node_modules')
) === 0
)
}
}),
// extract webpack runtime and module manifest to its own file in order to
// prevent vendor hash from being updated whenever app bundle is updated
// 提取公共代碼
new webpack.optimize.CommonsChunkPlugin({
// 把公共的部分放到 manifest 中
name: 'manifest',
// 傳入 `Infinity` 會馬上生成 公共chunk,但里面沒有模塊。
minChunks: Infinity
}),
// This instance extracts shared chunks from code splitted chunks and bundles them
// in a separate chunk, similar to the vendor chunk
// see: https://webpack.js.org/plugins/commons-chunk-plugin/#extra-async-commons-chunk
// 提取動態(tài)組件
new webpack.optimize.CommonsChunkPlugin({
name: 'app',
// 如果設置為 `true`,一個異步的 公共chunk 會作為 `options.name` 的子模塊,和 `options.chunks` 的兄弟模塊被創(chuàng)建。
// 它會與 `options.chunks` 并行被加載??梢酝ㄟ^提供想要的字符串,而不是 `true` 來對輸出的文件進行更換名稱。
async: 'vendor-async',
// 如果設置為 `true`,所有 公共chunk 的子模塊都會被選擇
children: true,
// 最小3個,包含3,chunk的時候提取
minChunks: 3
}),北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產業(yè)為響應國家深化產教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產業(yè)鏈。利用北京大學優(yōu)質教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。