【vue】路由懒加载

6 篇文章 0 订阅

vue路由懒加载指打包部署的时候按照对应的页面进行划分,需要的时候加载对应的页面资源,不是一次性加载所有的资源。

// 非懒加载
import Home from '@/components/Home'
 
const routes = [
  {
    path: '/home',
    name: 'home',
    component: Home
  }
]

三种按需加载的方式

1.异步组件

vue-router配置路由,用vue的异步组件技术对资源进行按需加载。

以下这种方式,每个组件都会生成一个js文件,不能分类制定chunkName。

// vue异步组件
{
  path: '/home',
  name: 'home',
  component: resolve => require(['@/components/home'], resolve)
}

2.import

// const 组件名 = () => import('组件路径');
// 下面2行代码,没有指定webpackChunkName,每个组件打包成一个js文件。
const Home = () => import('@/componnets/home');
const Index = () => import('@/components/index');
 
// 下面2行代码,指定了相同的webpackChunkName,会合并打包成一个js文件
// 把组件按组分块
const Home = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '@/components/home');
const Index = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '@/components/index')
 
{
  path: '/home',
  name: 'home',
  component: Home
}, {
  path: '/index',
  name: 'index',
  component: Index
}

3.webpack的require.ensure()

可以制定相同的chunkName,合并打包成一个js文件。

{
  path: '/home',
  name: 'home',
  component: r => require.ensure([], () => r(require('@/components/home')), 'demo')
}, {
  path: '/index',
  name: 'index',
  component: r => require.ensure([], () => r(require('@/components/index')), 'demo')
}, {
  path: '/about',
  name: 'about',
  // 传入空字符串 则每个component会单独生成一个js文件
  component: r => require.ensure([], () => r(require('@/components/index')), '')
}

正常情况下打包,每个路由对应的component都会生成一个js文件,如果项目中有几百个路由,就会生成几百个js文件,是没有必要的,可以通过webpackChunkName将模块进行分类,减少打包生成的文件数量。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Vite 和 Vue 中,你可以使用路由来优化你的应用的性能。下面是一个简单的示例来演示如何在 Vite 中使用 Vue 路由: 首先,确保你已经安装了 `vue-router` 和 `@vue/compiler-sfc`,你可以使用以下命令进行安装: ``` npm install vue-router @vue/compiler-sfc ``` 接下来,在你的项目中创建一个路由文件,比如 `router.js`,并编写你的路由配置。在配置路由时,可以使用 `import` 语法来实现。 ```javascript import { createRouter, createWebHistory } from 'vue-router' const routes = [ { path: '/', name: 'Home', component: () => import('./views/Home.vue') // 使用 }, { path: '/about', name: 'About', component: () => import('./views/About.vue') // 使用 } ] const router = createRouter({ history: createWebHistory(), routes }) export default router ``` 在上面的代码中,`import()` 函数用于异步组件。这样,当用户访问某个路由时,对应的组件将会被动态并渲染。 最后,在你的主入口文件(比如 `main.js`)中导入路由,并将其挂Vue 实例上。 ```javascript import { createApp } from 'vue' import App from './App.vue' import router from './router' createApp(App) .use(router) .mount('#app') ``` 现在,你已经成功地在 Vite 中配置了 Vue 路由。每次用户访问特定的路由时,相关的组件将会按需,从而提高了应用的性能和速度。 希望对你有帮助!如果你还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值