当前位置: 首页 > news >正文

【vue-router】Vue-router如何实现路由懒加载

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,Golang开发,云原生开发,前后端框架,PyQt5和Tkinter桌面开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生K8S集群搭建与管理,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:前端零基础,实战进阶教学
景天的主页:景天科技苑

文章目录

  • Vue-Router路由懒加载
    • 一、Vue-Router简介
    • 二、什么是路由懒加载
    • 三、路由懒加载的实现方式
      • 1. 箭头函数+import
      • 2. 箭头函数+require
      • 3. require.ensure
    • 四、动态路由和懒加载
      • 1. 定义动态路由
      • 2. 获取动态参数
    • 五、路由懒加载的最佳实践
      • 1. 合理使用代码分割
      • 2. 使用Webpack的prefetch和preload指令

Vue-Router路由懒加载

在现代前端开发中,Vue.js凭借其轻量级和易用性,成为了很多开发者的首选框架。然而,在构建大型单页应用(SPA)时,初始加载时间可能会变得非常长,影响用户体验。为了解决这个问题,Vue.js引入了路由懒加载机制。本文将结合实际案例,详细讲解Vue-Router路由懒加载的用法。

一、Vue-Router简介

Vue Router是Vue.js官方的路由管理器,它允许你以一种简单的方式构建单页面应用中的页面路由。Vue Router提供了强大的路由管理功能,包括嵌套路由、动态路由、路由守卫等。

要使用Vue Router,首先需要安装它。你可以通过npm或yarn进行安装:

npm install vue-router
# 或者
yarn add vue-router

安装完成后,你需要在Vue项目中配置Vue Router。下面是一个简单的配置示例:

import Vue from 'vue';
import Router from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';Vue.use(Router);const router = new Router({routes: [{ path: '/', component: Home },{ path: '/about', component: About },],
});export default router;

在上述代码中,我们定义了两个路由:首页(/)和关于页(/about)。当用户访问这些路由时,对应的组件会被渲染到页面上。

二、什么是路由懒加载

在构建大型单页应用时,如果将所有路由和组件都打包在一起,会导致初始加载时间非常长。为了解决这个问题,Vue.js引入了路由懒加载机制。路由懒加载是指只有在需要访问某个路由时,才加载该路由对应的组件代码。这样可以显著减少初始加载时间,提高应用程序的性能。

Vue Router的懒加载依赖于Webpack的代码分割功能。Webpack会将每个懒加载的组件打包成一个独立的代码块(chunk),并在需要时动态加载。

三、路由懒加载的实现方式

Vue Router的懒加载可以通过多种方式实现,主要包括箭头函数+import、箭头函数+require以及require.ensure等。以下是这些方式的详细介绍和示例。

1. 箭头函数+import

这是Vue Router懒加载中最推荐的方式,因为它语法简洁、直观易懂,并且符合现代JavaScript标准。使用箭头函数和import()函数可以实现路由的懒加载。

const Home = () => import('./components/Home.vue');
const About = () => import('./components/About.vue');const router = new Router({routes: [{ path: '/', component: Home },{ path: '/about', component: About },],
});

在上述代码中,Home和About组件都是通过箭头函数和import()函数实现的懒加载。当用户访问首页或关于页时,对应的组件才会被加载。

你还可以为生成的代码块指定名称,以便更好地管理和调试。

const Home = () => import(/* webpackChunkName: "home" */ './components/Home.vue');
const About = () => import(/* webpackChunkName: "about" */ './components/About.vue');

这样,Webpack会将Home和About组件分别打包成名为home.jsabout.js的代码块。

2. 箭头函数+require

在一些旧版本的构建工具中,你可能会看到使用箭头函数和require()函数来实现路由懒加载的方式。虽然这种方式仍然有效,但相对于箭头函数+import来说,它的语法相对复杂,不够直观。

const router = new Router({routes: [{path: '/',component: resolve => require(['./components/Home.vue'], resolve),},{path: '/about',component: resolve => require(['./components/About.vue'], resolve),},],
});

在上述代码中,Home和About组件都是通过箭头函数和require()函数实现的懒加载。当用户访问首页或关于页时,对应的组件才会被加载。

需要注意的是,require()函数是CommonJS规范中的模块导入方式,而在现代JavaScript开发中,ES6的import/export规范更为常用。因此,推荐使用箭头函数+import的方式来实现路由懒加载。

3. require.ensure

require.ensure是Webpack 1.x版本中用于代码分割和懒加载的API。然而,在Webpack 2.x及以上版本中,require.ensure已经被废弃,推荐使用动态import(即import()函数)来替代。因此,在现代Vue项目中,你几乎不会看到使用require.ensure来实现路由懒加载的情况。

不过,为了完整性,这里还是简单介绍一下require.ensure的用法。

const Home = r => require.ensure([], () => r(require('./components/Home.vue')), 'home');
const About = r => require.ensure([], () => r(require('./components/About.vue')), 'about');const router = new Router({routes: [{ path: '/', component: Home, name: 'Home' },{ path: '/about', component: About, name: 'About' },],
});

在上述代码中,Home和About组件都是通过require.ensure实现的懒加载。然而,由于require.ensure已经被废弃,这种方式在现代Vue项目中不再推荐使用。

四、动态路由和懒加载

在Vue Router中,动态路由允许你定义路径时使用占位符,这些占位符将会被实际的数值所替代。通过动态路由和懒加载的结合,你可以实现更加灵活和高效的路由管理。

1. 定义动态路由

动态路由的定义非常简单,只需要在路径中使用占位符即可。例如,定义一个动态路由/user/:id,其中:id就是动态的参数。

const UserProfile = () => import('./components/UserProfile.vue');const router = new Router({routes: [{ path: '/user/:id', component: UserProfile, name: 'UserProfile' },],
});

在上述代码中,我们定义了一个动态路由/user/:id,并为其指定了UserProfile组件。当用户访问/user/123时,UserProfile组件会被加载,并且可以通过$route.params.id来获取传递过来的动态参数id

2. 获取动态参数

在组件中,你可以通过$route.params来获取传递过来的动态参数。例如,在UserProfile组件中,你可以这样获取id参数:

export default {created() {console.log(this.$route.params.id); // 输出传递过来的id参数},
};

五、路由懒加载的最佳实践

在使用Vue Router的懒加载功能时,有一些最佳实践可以帮助你更好地优化应用程序的性能和用户体验。

1. 合理使用代码分割

代码分割是Webpack的一个重要功能,它可以将代码拆分成多个独立的代码块,并在需要时动态加载。在使用Vue Router的懒加载功能时,你应该合理使用代码分割,将不同的路由组件拆分成不同的代码块。

例如,你可以将首页、关于页、用户详情页等不同的路由组件拆分成不同的代码块,并在需要时动态加载它们。

const Home = () => import(/* webpackChunkName: "home" */ './components/Home.vue');
const About = () => import(/* webpackChunkName: "about" */ './components/About.vue');
const UserProfile = () => import(/* webpackChunkName: "userProfile" */ './components/UserProfile.vue');const router = new Router({routes: [{ path: '/', component: Home, name: 'Home' },{ path: '/about', component: About, name: 'About' },{ path: '/user/:id', component: UserProfile, name: 'UserProfile' },],
});

2. 使用Webpack的prefetch和preload指令

Webpack提供了prefetch和preload指令,可以帮助你更好地优化代码的加载性能。prefetch指令会在浏览器空闲时预加载指定的代码块,而preload指令则会在当前代码块加载时立即预加载指定的代码块。

你可以在使用Vue Router的懒加载功能时,结合Webpack的prefetch和preload指令来进一步优化代码的加载性能。

const Home = () => import(/* webpackPrefetch: true */ './components/Home.vue');
const About = () => import(/* webpackPreload: true */ './components/About.vue');const router = new Router({routes: [{ path: '/', component: Home, name: 'Home' },{ path: '/about', component: About, name: 'About' },],
});

在上述代码中,我们使用了Webpack的prefetch和preload指令来优化Home和About组件的加载性能。需要注意的是,preload指令通常用于关键路径上的代码块,而prefetch指令则用于非关键路径上的代码块。

相关文章:

【vue-router】Vue-router如何实现路由懒加载

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…...

Linux网络编程基础

目录 一、网络发展历史和分层 1.1Internet的历史 1.2网络的体系结构 1.2.1OSI模型 1.2.2TCP/IP协议族 1.2.3各层典型协议 1.2.4网络的封包和拆包 二、网络编程的预备知识 2.1Socket 2.1.1概念 2.1.2类型 2.2IP地址 2.3端口号 2.4字节序 一、网络发展历史和分层 …...

MySQL中的幻读问题

1. 什么是幻读? 幻读是一种数据库事务中可能出现的并发问题,具体表现为:在同一个事务中,前后两次查询的结果集不同,仿佛“幻影”一般,出现了原本不存在的数据。 1.1 具体表现: 现象描述 事务 A…...

AI后端工程师面试题的内容

AI后端工程师面试题主要包括以下几个方面的内容‌: ‌一、技术基础和项目经验‌: ‌1. 微服务架构的理解和应用‌:请描述你对微服务架构的理解,并举例说明一个你参与过的微服务项目,阐述你在该项目中扮演的角色和所承…...

MFC工控项目实例三十五读取数据库数据

点击按钮打开文件夹中的数据文件生成曲线 相关代码 void CSEAL_PRESSUREDlg::OnTesReport() {CFileDialog dlgOpen(TRUE/*TRUE打开,FALSE保存*/,0,0,OFN_NOCHANGEDIR|OFN_FILEMUSTEXIST,"All Files(mdb.*)|*.*||",//文件过滤器NULL);CString mdb_1, m…...

OpenWrt -制作ubifs文件系统的固件

目的 创建一个ubifs为文件系统的镜像 将backup目录中的内容打包成ubifs文件系统。 ubifs的分区定义 ubi-backup.cfg 文件内容如下, [backup] modeubi imagenand-ipq6018-single.img vol_id0 vol_typedynamic vol_namebackup [bkver] modeubi imagebackup.ubifs v…...

C++ - 继承

继承的基本概念 继承就是一种代码的复用. 子类通过继承父类, 就能使用父类的变量, 方法. 学生和老师这两种身份, 他们都有共同的属性: 他们都有名称, 年龄, 性别 .... 当然他们也有各种独有的属性, 学生有学号, 老师有工号 .... 对于这些共有的属性, 我们可以将它们提取出来: …...

华为服务器使用U盘重装系统

一、准备工作 下载官方系统(注意服务器CPU的架构是x86-64还是aarch64,不然可能报意想不到的错)制作启动U盘(下载rufus制作工具,注意文件系统选FAT32还是NTFS) 二、安装步骤 将U盘插入USB接口重启服务器…...

网络分层模型( OSI、TCP/IP、五层协议)

1、网络分层模型 计算机网络是一个极其复杂的系统。想象一下最简单的情况:两台连接在网络上的计算机需要相互传输文件。不仅需要确保存在一条传输数据的通路,还需要完成以下几项工作: 发起通信的计算机必须激活数据通路,这包括发…...

前端开发 之 15个页面加载特效上【附完整源码】

文章目录 一:彩球环绕加载特效1.效果展示2.HTML完整代码 二:跷跷板加载特效1.效果展示2.HTML完整代码 三:两个圆形加载特效1.效果展示2.HTML完整代码 四:半环加载特效1.效果展示2.HTML完整代码 五:音乐波动加载特效1.效…...

Spring Boot使用JDK 21虚拟线程

JDK 21引入的虚拟线程(Virtual Threads)是 Project Loom 的一部分,旨在显著简化并发编程并提高 Java 应用的可扩展性。以下是虚拟线程的主要特点: 1. 概念 虚拟线程是轻量级线程,与传统的操作系统线程不同&#xff0…...

《从0到1常用Map集合核心摘要 + 不深不浅底层核心》

《从0到1常用Map集合核心摘要不深不浅底层核心》 前置知识 什么是键值对 ​ 键值对是一种数据结构,键是唯一标识,值是对应数据,用来快速查找信息。例: {"name": "Alice"},键是name,…...

12 设计模式之工厂方法模式

一、什么是工厂方法模式? 1.定义 在软件开发中,设计模式 是解决常见软件设计问题的最佳实践。而 工厂方法模式(Factory Method Pattern) 作为创建型设计模式之一,常常被用来解决对象创建问题。它通过将对象的创建交给…...

spaCy 入门与实战:强大的自然语言处理库

spaCy 入门与实战:强大的自然语言处理库 spaCy 是一个现代化、工业级的自然语言处理(NLP)库,以高效、易用和功能丰富著称。它被广泛应用于文本处理、信息提取和机器学习任务中。本文将介绍 spaCy 的核心功能,并通过一…...

python包的管理和安装——笔记

1.列出包 pip list pip freeze 用这2个可以查看当前python 下所有的包和版本,还有下载地址 如果只是想导出当前的环境 可以用 2.安装pipreqs pip install pipreqs,pipreqs ./可以导出当前项目的包这个包 遇到编码报错 pipreqs ./ --encodingutf8 p…...

Vue前端页面内嵌套本项目iframe窗口的通信传输方式

一、目的 想要在iframe中使用本项目页面、并能够与其父页面组件实现实时通信。Vue前端页面内嵌套本项目iframe窗口的通信传输方式-星林社区 https://www.jl1mall.com/forum/PostDetail?postId20241202172800023969 二、iframe通信方式 1.接收消息 页面需要监听 message 事件…...

【WEB开发.js】addEventListener事件监听器的绑定和执行次数的问题(小心踩坑)

假设我们有一个按钮,用户点击该按钮后,会选择一个文件,且我们希望每次点击按钮时只触发一次文件处理。下面我会给你一个简单的例子,展示放在函数内部和放在函数外部的区别。 1. 将事件监听器放在函数内部(问题的根源&…...

用于LiDAR测量的1.58um单芯片MOPA(一)

--翻译自M. Faugeron、M. Krakowski1等人2014年的文章 1.简介 如今,人们对高功率半导体器件的兴趣日益浓厚,这些器件主要用于遥测、激光雷达系统或自由空间通信等应用。与固态激光器相比,半导体器件更紧凑且功耗更低,这在低功率供…...

【GPT】代谢概念解读

以下是对代谢中分解代谢和合成代谢两个概念的深入解读,用简单易懂的方式展开说明: 1. 分解代谢(Catabolism) 什么是分解代谢? 分解代谢是身体把大分子“拆开”的过程。就像把一个三明治分解成面包片、肉片和菜叶&#…...

Devops-git篇-01-git环境配置

环境配置 设置用户签名 配置用户名: git config --global user.name 你的用户名 配置邮箱: git config --global user.email 注册的邮箱 配置好之后,可以用git config --global --list命令查看配置是否OK $ git config --global --list u…...

日语AI面试高效通关秘籍:专业解读与青柚面试智能助攻

在如今就业市场竞争日益激烈的背景下,越来越多的求职者将目光投向了日本及中日双语岗位。但是,一场日语面试往往让许多人感到步履维艰。你是否也曾因为面试官抛出的“刁钻问题”而心生畏惧?面对生疏的日语交流环境,即便提前恶补了…...

大数据零基础学习day1之环境准备和大数据初步理解

学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 (1)设置网关 打开VMware虚拟机,点击编辑…...

《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》

在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中&#xff0…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...

Spring AI与Spring Modulith核心技术解析

Spring AI核心架构解析 Spring AI(https://spring.io/projects/spring-ai)作为Spring生态中的AI集成框架,其核心设计理念是通过模块化架构降低AI应用的开发复杂度。与Python生态中的LangChain/LlamaIndex等工具类似,但特别为多语…...

GC1808高性能24位立体声音频ADC芯片解析

1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率&#xff0c…...

无人机侦测与反制技术的进展与应用

国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...

C++课设:简易日历程序(支持传统节假日 + 二十四节气 + 个人纪念日管理)

名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏介绍:《编程项目实战》 目录 一、为什么要开发一个日历程序?1. 深入理解时间算法2. 练习面向对象设计3. 学习数据结构应用二、核心算法深度解析…...

tomcat指定使用的jdk版本

说明 有时候需要对tomcat配置指定的jdk版本号,此时,我们可以通过以下方式进行配置 设置方式 找到tomcat的bin目录中的setclasspath.bat。如果是linux系统则是setclasspath.sh set JAVA_HOMEC:\Program Files\Java\jdk8 set JRE_HOMEC:\Program Files…...

水泥厂自动化升级利器:Devicenet转Modbus rtu协议转换网关

在水泥厂的生产流程中,工业自动化网关起着至关重要的作用,尤其是JH-DVN-RTU疆鸿智能Devicenet转Modbus rtu协议转换网关,为水泥厂实现高效生产与精准控制提供了有力支持。 水泥厂设备众多,其中不少设备采用Devicenet协议。Devicen…...