當打包構(gòu)建應(yīng)用時蘸际,Javascript 包會變得非常大座哩,影響頁面加載。如果我們能把不同路由對應(yīng)的組件分割成不同的代碼塊粮彤,然后當路由被訪問的時候才加載對應(yīng)組件根穷,這樣就更加高效了。
實現(xiàn):
1. vue異步組件技術(shù)
- vue-router配置路由导坟,使用vue的異步組件技術(shù)屿良,可以實現(xiàn)按需加載(懶加載)。
但是惫周,這種情況下一個組件生成一個js文件尘惧。
舉例如下:
{
path: '/promisedemo',
name: 'PromiseDemo',
component:
resolve => require(['../components/PromiseDemo'], resolve)
}
2. es提案的import()
- 推薦使用這種方式(需要webpack > 2.4)
- webpack官方文檔:webpack中使用
import()
vue官方文檔:路由懶加載使用import()
- vue-router配置路由,代碼如下:
// 下面2行代碼递递,沒有指定webpackChunkName喷橙,每個組件打包成一個js文件。
const ImportFuncDemo1 = () => import('../components/ImportFuncDemo1')
const ImportFuncDemo2 = () => import('../components/ImportFuncDemo2')
// 下面2行代碼漾狼,指定了相同的webpackChunkName重慢,會合并打包成一個js文件。
// const ImportFuncDemo = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/ImportFuncDemo')
// const ImportFuncDemo2 = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/ImportFuncDemo2')
export default new Router({
routes: [
{
path: '/importfuncdemo1',
name: 'ImportFuncDemo1',
component: ImportFuncDemo1
},
{
path: '/importfuncdemo2',
name: 'ImportFuncDemo2',
component: ImportFuncDemo2
}
]
})
3. webpack提供的require.ensure()
- vue-router配置路由逊躁,使用webpack的require.ensure技術(shù),也可以實現(xiàn)按需加載隅熙。
這種情況下稽煤,多個路由指定相同的chunkName核芽,會合并打包成一個js文件。
舉例如下:
{
path: '/promisedemo',
name: 'PromiseDemo',
component: r => require.ensure([], () => r(require('../components/PromiseDemo')), 'demo')
},
{
path: '/hello',
name: 'Hello',
// component: Hello
component: r => require.ensure([], () => r(require('../components/Hello')), 'demo')
}