VUE系列之性能优化--懒加载
一、懒加载的基本概念
懒加载是一种按需加载技术,即在用户需要时才加载相应的资源,而不是在页面初始加载时一次性加载所有资源。这样可以减少页面初始加载的资源量,提高页面加载速度和用户体验。
二、Vue 中的懒加载
在 Vue.js 中,懒加载主要用于路由组件的按需加载。Vue Router 提供了非常便捷的懒加载支持。
1. 路由懒加载
在传统的方式中,所有的路由组件会在页面初始化时一次性加载,如下所示:
import Home from './components/Home.vue';
import About from './components/About.vue'; const routes = [
{ path: '/', component: Home },
{ path: '/about', component: About }
];
这种方式在页面变得复杂和庞大时,会导致初始加载时间过长。通过懒加载,可以将组件按需加载:
const Home = () => import('./components/Home.vue');
const About = () => import('./components/About.vue');
const routes = [
{ path: '/', component: Home },
{ path: '/about', component: About }
];
在上述代码中,import() 函数会返回一个 Promise 对象,当路由被访问时才会加载相应的组件。
2. 组件懒加载
除了路由懒加载,Vue 还支持组件的懒加载。对于一些大型组件,可以使用异步组件的方式进行懒加载:
Vue.component('AsyncComponent', () => ({
// 需要加载的组件 (应该是一个 `Promise` 对象)
component: import('./components/AsyncComponent.vue'),
// 加载中应显示的组件
loading: LoadingComponent,
// 加载失败时显示的组件
error: ErrorComponent,
// 展示加载中组件前的延迟时间 (默认值是 200ms)
delay: 200,
// 加载失败后展示错误组件的延迟时间
timeout: 3000
}));
三、懒加载的实际应用
为了更好地理解懒加载的实际应用,我们来看一个具体的示例。假设我们有一个电商网站,有首页、商品详情页和购物车页。我们希望在用户访问首页时只加载首页的内容,只有在用户点击进入商品详情页或购物车页时,才加载相应的组件。
首先,设置路由和懒加载组件:
import Vue from 'vue';
import VueRouter from 'vue-router'; Vue.use(VueRouter); const Home = () => import('./components/Home.vue');
const ProductDetail = () => import('./components/ProductDetail.vue');
const Cart = () => import('./components/Cart.vue'); const routes = [
{ path: '/', component: Home },
{ path: '/product/:id', component: ProductDetail },
{ path: '/cart', component: Cart }
]; const router = new VueRouter({
routes
}); new Vue({
router,
render: h => h(App)
}).$mount('#app');
然后,在组件内部可以继续使用异步组件的方式进行懒加载,例如在 ProductDetail.vue 组件中:
<template>
<div>
<h1>Product Detail</h1>
<async-component></async-component>
</div>
</template> <script>
export default {
components: {
'async-component': () => import('./AsyncComponent.vue')
}
};
</script>
四、懒加载的注意事项
加载占位符:在懒加载过程中,为了提升用户体验,可以使用加载占位符组件(如加载动画或提示)。
错误处理:在组件加载失败时,应提供友好的错误提示或重试机制。
优化网络请求:可以结合服务端支持的 HTTP/2、多路复用等技术,进一步优化资源加载效率。
SEO 影响:对于需要 SEO 的页面,可以考虑使用服务端渲染(SSR)或预渲染(Prerendering)技术来解决懒加载带来的 SEO 问题。
五、总结
懒加载是一种非常有效的前端性能优化技术,在 Vue.js 中,主要通过路由懒加载和组件懒加载来实现。通过按需加载资源,可以显著减少页面初始加载时间,提高页面的响应速度和用户体验。在实际项目中,可以根据具体需求和场景,灵活应用懒加载技术,并结合其他优化手段,进一步提升前端性能。
VUE系列之性能优化--懒加载的更多相关文章
- [转]JavaScript 的性能优化:加载和执行
原文链接:http://www.ibm.com/developerworks/cn/web/1308_caiys_jsload/index.html?ca=drs- JavaScript 的性能优化: ...
- 【转】js JavaScript 的性能优化:加载和执行
JavaScript 的性能优化:加载和执行 转自:https://www.ibm.com/developerworks/cn/web/1308_caiys_jsload/ 随着 Web2.0 技术的 ...
- vue(18)路由懒加载
什么是路由懒加载 官方的解释: 当打包构建应用时,JavaScript 包会变得非常大,影响页面加载. 如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更 ...
- vue性能优化1--懒加载
懒加载也叫延迟加载,即在需要的时候进行加载.随用随载.为什么需要懒加载?像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,时间 ...
- 基于Vue的SPA如何优化页面加载速度
常见的几种SPA优化方式 减小入口文件体积 静态资源本地缓存 开启GZip压缩 使用SSR ..... 减小入口文件体积,常用的手段是路由懒加载,开启路由懒加载之后,待请求的页面会单独打包js文件,使 ...
- Vue.js笔记 — vue-router路由懒加载
用vue.js写单页面应用时,会出现打包后的JavaScript包非常大,影响页面加载,我们可以利用路由的懒加载去优化这个问题,当我们用到某个路由后,才去加载对应的组件,这样就会更加高效,实现代码如下 ...
- vue项目中实现图片懒加载的方法
对于图片过多的页面,为了加速页面加载速度,所以很多时候我们需要将页面内未出现在可视区域内的图片先不做加载, 等到滚动到可视区域后再去加载.这样子对于页面加载性能上会有很大的提升,也提高了用户体验. 实 ...
- Vue项目中实现图片懒加载
个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! ---对于图片过多的页面,为了加速页面加载速度,所以很多时候我们需要将页面 ...
- vue+webpack2实现路由的懒加载
当打包构建应用时,Javascript 包会变得非常大,影响页面加载.如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了. 结合 Vue 的异步组 ...
- 使用 vant 的 v-lazy 实现图片 vue 在移动端的懒加载
官方文档:https://youzan.github.io/vant/#/zh-CN/lazyload 引入 Lazyload 是 Vue 指令,使用前需要对指令进行注册 import Vue fro ...
随机推荐
- Java21新特性-虚拟线程
虚拟线程是轻量级线程(类似于 Go 中的 "协程(Goroutine)"),可以减少编写.维护和调度高吞吐量并发应用程序的工作量. 线程是可供调度的最小处理单元,它与其他类似的处理 ...
- 【2023全网最全最火】Selenium WebDriver教程(建议收藏)
在本教程中,我将向您介绍 Selenium Webdriver,它是当今市场上使用最广泛的自动化测试框架.它是开源的,可与所有著名的编程语言(如Java.Python.C#.Ruby.Perl等)一起 ...
- S212-搜索+字典树-212. Word Search II-(Hard)
一.题目 题目很简单,输入一个字母组成的二维数组,以某一个字母为起点,向.上下左右搜索.练成的字符看是不是在给定的字符串数组中 二.解答 通过深度优先搜索,每一步和数组中的字符串匹配是可以计算出来正确 ...
- Qt初始化代码基本说明
参考视频:黑马程序员https://www.bilibili.com/video/BV1XW411x7NU?p=4 1 工程基本介绍 按照这个基本步骤(https://www.cnblogs.com ...
- kettle从入门到精通 第四十九课 ETL之kettle 自定义插件01
1.kettle插件是什么 kettle本身有足够多的转换或者job步骤,但是依然不能覆盖所有的业务场景,所以Kettle 自定义插件在有些独特的业务场景可以大显身手. Kettle的插件架构使得我们 ...
- .net执行oracle查询语句报错“指定的转换无效”解决方案
问题: .net执行oracle查询语句报错"指定的转换无效",在PL/SQL中正常: SELECT A.ID,SUM(TO_NUMBER(A.MODIFYTIME-A.UPLOA ...
- star 最多的 Go 语言本地化库|GitHub 2.8K
如果你是一位 Go 用户,可以在我开源的学习仓库中,找到针对各种往期归档文章,及学习资料. B站:白泽talk,公众号[白泽talk],回复"电子书",即可获得包含<100个 ...
- spring项目中读取resources下的文件
spring项目中读取resources下的文件 我们都知道,spring项目经过maven打包后,可以打成jar包或可解压的war包 a. war包是需要外置的web容器去运行的,是需要先解压的 b ...
- 燕千云 YQCloud 数智化业务服务平台 发布1.12版本
2022年4月29日,燕千云 YQCloud 数智化业务服务平台发布1.12版本,优化客户服务场景.深化智能预测服务的应用,加强系统在多渠道方面的集成,全面提升企业数智化服务的能力! 作为企业数字化服 ...
- xxlJob Cron表达式 0 0 8,13 * * ?
xxlJob Cron表达式 0 0 8,13 * * ? Cron有如下两种语法格式:(1)Seconds Minutes Hours DayofMonth Month DayofWeek Yea ...