这篇文章主要介绍“vue性能优化技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue性能优化技巧有哪些”文章能帮助大家解决问题。在所有的web前台项目,静态资源基本都放在cdn上,gzip的压缩是非常必要的,它直接改变了js文件的大小,减少两到三倍。参考加速nginx: 开启gzip和缓存,nginx的gzip配置非常简单,在你对应的域名底下,增加下面的配置,重启服务就可。gzip_comp_level
的值大于2的时候并不显著,建议设置在1或者者2之间。为了提高服务器获取数据的速度,nginx缓存着静态资源是非常必要的。假如是测试服务器对html应该不设置缓存,而js等静态资源环境由于文件尾部会加上一个hash值,这可以有效实现缓存的控制。浏览器缓存是通过html的头文件中的meta来控制。http-equiv
是一个专门针对http的头文件,可以向浏览器传回少量有用的信息。与之对应的content,是各个参数的变量值。在HTTP1.0中通过Pragma控制页面缓存,可以设置为Pragma或者no-cache。在不让浏览器或者中间缓存服务器缓存页面的情况下,通常设置的值为no-cache,不过这个值不这么保险,通常还加上Expires置为0来达到目的。Expires可以用于设定网页的到期时间。一旦网页过期,必需到服务器上重新传输获取新的页面信息。PS:内容必需使用GMT的时间格式。在HTTP1.1中通过Cache-Control控制页面缓存,可以设置为no-cache、private、no-store、max-age或者must-revalidate等,默认为private。public 浏览器和缓存服务器都可以缓存页免费云主机域名面信息private 对于单个客户的整个或者部分响应消息,不能被共享缓存解决。这允许服务器仅仅形容当客户的部分响应消息,此响应消息对于其余客户的请求无效no-cache 浏览器和缓存服务器都不应该缓存页面信息no-store 请求和响应的信息都不应该被存储在对方的磁盘系统中,不使用缓存must-revalidate 对于用户机的每次请求,代理商服务器必需想服务器验证缓存能否过时max-age 用户机可以接收生存期不大于指定时间(以秒为单位)的响应min-fresh 用户机可以接收响应时间小于当前时间加上指定时间的响应Last-Modified服务器端文件响应头,形容最后修改时间。当浏览器再次进行请求时,会向服务器传送If-Modified-Since报头,讯问时间点之后资源能否被修改过,从而区分200和304的请求状态码,304则选择浏览器缓存。Etags不同的是,ETag是根据实体内容生成一段hash字符串,是标识资源的状态。它由服务端产生来判断文件能否有升级。参考资料:HTTP缓存深入实践掌握缓存,不再让你蓝瘦香菇前面说的两部分都可以说是偏后台的活,假如真的从前台方面考虑,我们可能会分包入手。正由于vue的脚手架搭建的项目,webpack的配置当中就包含了压缩js,css和html的压缩。所以,当我们的单页面越做越大的情况下,首要的一步就是分包。vue官方称gzip压缩后只有20kb,但是你普通的打包方式也有100kb,再加上你自己的逻辑代码,整体包的体积也挺大的。直接影响首屏页面加载的效率。下面详情一下两种分包的方法:external 把包排除,使用cdn资源dll 打包在webpack配置文件中external设置,把这三个场用包排除这个操作,主要是把这三个包从vendor.js分开。最后当然需要在html标签上增加上额外cdn的link或者者script。这种打包方式专门引用webpack官方的DllPlugin和DllReferencePlugin。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可以减少这部分的时间。预加载也可以对某个静态资源起到专门的作用。预渲染(pre-rendering)是这个页面会提前加载好客户即将访问的下一个页面。假如你做用一个大型web的spa的时候,你有很多router,对应的是很多个页面。在页面的快速切换中,为了保证页面加载的效率,除了缓存机制之外,vue的keep-alive组件可以帮的上忙。它会把组件保存在浏览器内存当中,方便你快速切换。百度的lavas项目中就在vue-router当中使用keep-alive的组件,用它包裹着router-view。使用了keep-alive的组件内的数据将会保留,“能否需要重新同步数据”可以在vue-router的钩子中路由所带的参数执行判断。es6的其中一个特性就是原生支持promise。在这里,我先不说异步编程里的generator和aync/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的封装。Promise的使用需要避免以下的写法,尽量使用链式写法,并行的操作主要是Promise.all()
,它可以将Promise操作的数组并行执行完成而后在进行串行的操作。Promise.race()
则是返回并行请求中最先返回的请求的那个结果。它们的使用可以有效地压缩数据获取的时间。Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运行速度快等优势,Vue中页面使用的是局部刷新,不用每次跳转页面都要请求所有数据和dom,可以大大提升访问速度和用户体验。关于“vue性能优化技巧有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注百云主机行业资讯频道,小编每天都会为大家更新不同的知识点。
相关推荐: PHP laravel缓存cache机制怎么实现
今天小编给大家分享一下PHPlaravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。