我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue性能优化技巧有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue性能优化技巧有哪些

这篇文章主要介绍“vue性能优化技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue性能优化技巧有哪些”文章能帮助大家解决问题。

gzip压缩

在所有的web前台项目,静态资源基本都放在cdn上,gzip的压缩是非常必要的,它直接改变了js文件的大小,减少两到三倍。

参考加速nginx: 开启gzip和缓存,nginx的gzip配置非常简单,在你对应的域名底下,增加下面的配置,重启服务就可。gzip_comp_level的值大于2的时候并不显著,建议设置在1或者者2之间。

# 开启gzipgzip on;# 启用gzip压缩的最小文件,小于设置值的文件将不会压缩gzip_min_length 1k;# gzip 压缩级别,1-10,数字越大压缩的越好,也越占用CPU时间,后面会有详细说明gzip_comp_level 2;# 进行压缩的文件类型。javascript有多种形式。其中的值可以在 mime.types 文件中找到。gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;# 能否在http header中增加Vary: Accept-Encoding,建议开启gzip_vary on;# 禁用IE 6 gzipgzip_disable "MSIE [1-6]\.";

服务器缓存

为了提高服务器获取数据的速度,nginx缓存着静态资源是非常必要的。假如是测试服务器对html应该不设置缓存,而js等静态资源环境由于文件尾部会加上一个hash值,这可以有效实现缓存的控制。

location ~* ^.+\.(ico|gif|jpg|jpeg|png)$ {   access_log   off;   expires      30d;}location ~* ^.+\.(css|js|txt|xml|swf|wav)$ {  access_log   off;  expires      24h;}location ~* ^.+\.(html|htm)$ {  expires      1h;}

浏览器缓存

浏览器缓存是通过html的头文件中的meta来控制。http-equiv是一个专门针对http的头文件,可以向浏览器传回少量有用的信息。与之对应的content,是各个参数的变量值。

HTTP 1.0

在HTTP1.0中通过Pragma控制页面缓存,可以设置为Pragma或者no-cache。在不让浏览器或者中间缓存服务器缓存页面的情况下,通常设置的值为no-cache,不过这个值不这么保险,通常还加上Expires置为0来达到目的。Expires可以用于设定网页的到期时间。一旦网页过期,必需到服务器上重新传输获取新的页面信息。PS:内容必需使用GMT的时间格式。

<meta http-equiv="Pragma" content="no-cache"><meta http-equiv="Expires" content="0">

HTTP 1.1

在HTTP1.1中通过Cache-Control控制页面缓存,可以设置为no-cacheprivateno-storemax-age或者must-revalidate等,默认为private。

<meta http-equiv="Cache-Control" content="no-cache">
  • public 浏览器和缓存服务器都可以缓存页面信息

  • private 对于单个客户的整个或者部分响应消息,不能被共享缓存解决。这允许服务器仅仅形容当客户的部分响应消息,此响应消息对于其余客户的请求无效

  • no-cache 浏览器和缓存服务器都不应该缓存页面信息

  • no-store 请求和响应的信息都不应该被存储在对方的磁盘系统中,不使用缓存

  • must-revalidate 对于用户机的每次请求,代理商服务器必需想服务器验证缓存能否过时

  • max-age 用户机可以接收生存期不大于指定时间(以秒为单位)的响应

  • min-fresh 用户机可以接收响应时间小于当前时间加上指定时间的响应

Last-Modified和Etags

Last-Modified服务器端文件响应头,形容最后修改时间。当浏览器再次进行请求时,会向服务器传送If-Modified-Since报头,讯问时间点之后资源能否被修改过,从而区分200和304的请求状态码,304则选择浏览器缓存。

Etags不同的是,ETag是根据实体内容生成一段hash字符串,是标识资源的状态。它由服务端产生来判断文件能否有升级。

参考资料:

  • HTTP缓存深入实践

  • 掌握缓存,不再让你蓝瘦香菇

JS分包

前面说的两部分都可以说是偏后台的活,假如真的从前台方面考虑,我们可能会分包入手。正由于vue的脚手架搭建的项目,webpack的配置当中就包含了压缩js,css和html的压缩。所以,当我们的单页面越做越大的情况下,首要的一步就是分包。

vue官方称gzip压缩后只有20kb,但是你普通的打包方式也有100kb,再加上你自己的逻辑代码,整体包的体积也挺大的。直接影响首屏页面加载的效率。下面详情一下两种分包的方法:

  • external 把包排除,使用cdn资源

  • dll 打包

vue,vuex和vue-router

在webpack配置文件中external设置,把这三个场用包排除这个操作,主要是把这三个包从vendor.js分开。

最后当然需要在html标签上增加上额外cdn的link或者者script。

DLL打包

这种打包方式专门引用webpack官方的DllPluginDllReferencePlugin。DllPlugin会生成一个dll包的代码指纹manifest,管理额外的打包。而在项目生成的过程中,DllReferencePlugin会参考manifest的内容去打包。额外生成的js文件应该被放置在vue项目的文件当中的static文件夹底下,以便于代码部署。

参考PaicFE/vue-multi中的配置文件webpack.dll.config.js的写法。

预加载

预加载技术(prefetch)是在客户需要前我们就将所需的资源加载完毕,不是所有浏览器都支持,主要是Chrome浏览器。

DNS prefetch 分析这个页面需要的资源所在的域名,浏览器空闲时提前将这些域名转化为 IP 地址,真正请求资源时就避免了上述这个过程的时间。----HTML5 prefetch

因为域名转换成为IP的过程是非常耗时的一个过程,DNS prefetch可以减少这部分的时间。

<meta http-equiv='x-dns-prefetch-control' content='on'><link rel='dns-prefetch' href='http://g-ecx.images-amazon.com'><link rel='dns-prefetch' href='http://z-ecx.images-amazon.com'><link rel='dns-prefetch' href='http://ecx.images-amazon.com'><link rel='dns-prefetch' href='http://completion.amazon.com'><link rel='dns-prefetch' href='http://fls-na.amazon.com'>

预加载也可以对某个静态资源起到专门的作用。

<link rel='subresource' href='libs.js'>

预渲染(pre-rendering)是这个页面会提前加载好客户即将访问的下一个页面。

<link rel='prerender' href='http://www.pagetoprerender.com'>

vue组件keep-alive

假如你做用一个大型web的spa的时候,你有很多router,对应的是很多个页面。在页面的快速切换中,为了保证页面加载的效率,除了缓存机制之外,vue的keep-alive组件可以帮的上忙。

它会把组件保存在浏览器内存当中,方便你快速切换。

百度的lavas项目中就在vue-router当中使用keep-alive的组件,用它包裹着router-view。使用了keep-alive的组件内的数据将会保留,“能否需要重新同步数据”可以在vue-router的钩子中路由所带的参数执行判断。

Promise请求

es6的其中一个特性就是原生支持promise。在这里,我先不说异步编程里的generatoraync/await的属性。它们功能的实现都是基于promise。

Promise的特点在于:

  • 减少回调函数

  • 串并行解决

  • 代码的优雅

这里特别讲一下,ES6在性能优化上可以使用promise或者者async/await去压缩请求时间。在过去,很多jquery的页面在调用接口请求都是一个接口等另一个接口,串行执行所有请求,最后在完成最后的回调函数,如此类推。这样的写法会直接导致“回调地狱”。即便你用vue-resource,我也review到非常多的“回调地狱”的情况。为了从根本上处理这个问题并提高开发效率,我建议优先使用promise。(async/await不急着投入使用),考虑到还有很多同事还在高效地开发业务代码。

现在的vue-resource已经支持promise的写法,为了更好地让技术向后发展,我建议将pagekit/vue-resource替换称为mzabriskie/axios和webmodules/jsonp。axios是可以同时满足服务端和浏览器端,同构的写法有助于以后将技术栈往SSR(服务端渲染)发展。jsonp这个库则是为了兼容jsonp的请求需要,需要对它进行了promise的封装。

export function getJsonp(urlHost, key, data, _params) {  return new Promise((resolve, reject) => {    let url = urlHost + key;    if (data) url += `?${querystring.stringify({ ...data, temp: new Date().getTime() })}`;    const params = _params || { timeout: 15000 };    if (!params.timeout) params.timeout = 15000;    jsonp(url, params, (err, res) => {      if (err) {        reject(err);      } else {        resolve(res);      }    });  });}

Promise的使用需要避免以下的写法,

promise.then(function(value) {  // success}, function(error) {  // failure});

尽量使用链式写法,

promise.then(function(value) {  // step1}).then(function(value){  // step2}).catch(function(value){  // failure})

并行的操作主要是Promise.all(),它可以将Promise操作的数组并行执行完成而后在进行串行的操作。Promise.race()则是返回并行请求中最先返回的请求的那个结果。它们的使用可以有效地压缩数据获取的时间。

Vue的优点

Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运行速度快等优势,Vue中页面使用的是局部刷新,不用每次跳转页面都要请求所有数据和dom,可以大大提升访问速度和用户体验。

关于“vue性能优化技巧有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue性能优化技巧有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue性能优化技巧有哪些

这篇文章主要介绍“vue性能优化技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue性能优化技巧有哪些”文章能帮助大家解决问题。gzip压缩在所有的web前台项目,静态资源基本都放在cdn
2023-07-04

python性能优化技巧有哪些

小编给大家分享一下python性能优化技巧有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!性能优化技巧1. 限制CPU和内存使用量如果Python程序占用资源
2023-06-27

有哪些Java性能优化技巧

这篇文章主要讲解了“有哪些Java性能优化技巧”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“有哪些Java性能优化技巧”吧!  1.在你确认必要之前不要优化  你应该遵循常见的最佳实践做法并
2023-06-02

Vue开发中的性能优化技巧有哪些

这篇文章将为大家详细讲解有关Vue开发中的性能优化技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 长列表性能优化1. 不做响应式比如会员列表、商品列表之类的,只是纯粹的数据展示,不会有任何动
2023-06-29

优化Vue开发中的性能技巧有哪些

这篇文章主要介绍了优化Vue开发中的性能技巧有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇优化Vue开发中的性能技巧有哪些文章都会有所收获,下面我们一起来看看吧。1. 长列表性能优化1. 不做响应式比如会
2023-06-29

docker优化性能的技巧有哪些

以下是一些优化Docker性能的技巧:使用多阶段构建:多阶段构建可以减小镜像的大小,从而提高构建和部署的性能。使用合适的基础镜像:选择一个适合你的应用程序的基础镜像,这样可以减少不必要的依赖和组件,从而提高性能。优化Dockerfile:在
2023-10-25

mongodb性能优化的技巧有哪些

以下是一些MongoDB性能优化的技巧:索引优化:使用合适的索引可以大大提高查询性能。使用explain()命令来分析查询性能,并使用适当的索引来优化查询。适当的数据建模:正确的数据建模可以提高查询性能。根据查询需求和数据访问模式来设计数据
2023-10-25

Web性能优化的技巧有哪些

这篇文章主要介绍了Web性能优化的技巧有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Web性能优化的技巧有哪些文章都会有所收获,下面我们一起来看看吧。1. 使用文本压缩使用文本压缩,可以最大程度地减少通过
2023-06-27

Android性能优化的技巧有哪些

这篇“Android性能优化的技巧有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android性能优化的技巧有哪些”文
2023-06-04

Java性能的优化技巧有哪些

这篇文章主要讲解了“Java性能的优化技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java性能的优化技巧有哪些”吧!1.对象的生成和大小的调整。 JAVA程序设计中一个普遍的问题
2023-06-17

Laravel 5框架性能优化技巧有哪些

这篇文章主要讲解了“Laravel 5框架性能优化技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Laravel 5框架性能优化技巧有哪些”吧!1、配置缓存信息使用laravel自带
2023-06-04

php性能优化函数有哪些使用技巧?

对于使用PHP开发的网站或应用程序来说,性能优化是非常重要的。一个高性能的网站能够提供更好的用户体验,同时也能够减少服务器的负载。在优化PHP性能中,我们需要关注一些特定的函数和技巧。下面是一些常见的PHP性能优化函数的使用技巧。使用缓存函
2023-10-21

Golang应用程序性能优化技巧有哪些

这篇文章主要讲解了“Golang应用程序性能优化技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Golang应用程序性能优化技巧有哪些”吧!一、概述随着科技的进步,人人都想要快速的应
2023-07-06

MongoDB的性能调优技巧有哪些

使用索引:在MongoDB中,索引可以大大提高查询性能。通过创建适当的索引,可以加快查询速度,并减少查询时需要扫描的文档数量。需要根据实际需求创建合适的索引,以提高查询性能。使用适当的数据模型:设计合适的数据模型对性能也有很大的影响。在设计
MongoDB的性能调优技巧有哪些
2024-05-07

服务器端优化Web性能的技巧有哪些

今天小编给大家分享一下服务器端优化Web性能的技巧有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Tip #1: 通过反
2023-06-10

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录