浅谈vue项目可以从哪些方面进行优化


Posted in Javascript onMay 05, 2018

图片优化

1、图片大小优化,部分图片使用WebP(需要考虑webp兼容性)

  1. 在线生成,如智图、又拍云
  2. gulp生成,gulp-webp或gulp-imageisux
  3. canvas生成

2、减少图片请求,使用雪碧图

  1. 在线生成:sprites Generator、腾讯的gopng、spriteme
  2. 代码生成:gulp.spritesmith或者sass的compass

页面性能优化

图片或组件懒加载

使用vue-lazyload组件或其他一些组件

vue-lazyload地址: https://www.npmjs.com/package/vue-lazyload

图片懒加载:v-lazy或使用v-lazy-container包含一个图片组

// 引入一张图片 
<img v-lazy="//domain.com/img1.jpg"> 
// 引入一组图片
<div v-lazy-container="{ selector: 'img', error: 'xxx.jpg', loading: 'xxx.jpg' }">
 <img data-src="//domain.com/img1.jpg">
 <img data-src="//domain.com/img2.jpg">
 <img data-src="//domain.com/img3.jpg"> 
</div>

组件懒加载

Vue.use(VueLazyload, {
 lazyComponent: true
});
<lazy-component>
 <img class="mini-cover" :src="img.src" width="100%" height="400">
</lazy-component>

图片预加载

快速显示图片

使用场景:在某个查看图片的组件,当不断翻看下一页的图片时,从服务端获取数据再展示图片会出现图片缓慢加载的情况,此时可以在展示新数据时候先预加载图片,图片加载完之后在,将图片填充到对应位置

三方插件懒加载(按需加载)

js文件一般是同步加载的,放在页面内会阻塞主要js文件加载。

使用场景:有的项目必须引入jquery等文件时,在组件内部引入这些文件一定程度会阻塞页面渲染,因而通过特定事件(点击或者弹窗)动态加载jquery等JS文件,可以使主页面快速显示出来。

异步加载页面,如何让组件之间不重合

加载多个vue组件时,同时组件是通过服务端数据渲染时,会出现多个组件先重合后分离的状况

三种方案

  • 当页面展示的版块是固定的时候且内容高度不易变动时候,可以预先在组件外设置一个固定高度,显示的时候就像在一个框架里添加内容。当页面内容不固定时候,为了减少异步加载时组件重合的问题,可以在首屏在某组件数据加载完成时候设置其他组件显示,通过v-show显示。
  • 当页面整体固定时,可以为页面增加一个骨架,这样防止页面闪烁的情况。具体实施可以参照 https://3water.com/article/130505.htm
  • 服务端渲染页面,对于一些页面数据固定、更改较少的,可以考虑通过服务端渲染,会在短时间将页面显示出来,有比较好的用户体验。

减少引入外部文件大小

项目引入部分ElementUI内容时,通过引入babel-plugin-component配置.babelrc文件,这样即可引入部分组件,从而减少组件的大小。

路由懒加载

但使用到vue-router时,webpack会将所有组件打包在一个js文件中,这样就导致这个文件非常大,从而会影响首页的加载,最好的方法就是将其他路由分别打包到不同js文件中,切换路由时再加载对应js文件。

resolve => require([URL], resolve), 支持性好

() => system.import(URL) , webpack2官网上已经声明将逐渐废除, 不推荐使用

() => import(URL), webpack2官网推荐使用, 属于es7范畴, 需要配合babel的syntax-dynamic-import插件使用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
限制文本字节数js代码
Mar 06 Javascript
在JavaScript中通过URL传递汉字的方法
Apr 09 Javascript
Javascript 实现的数独解题算法网页实例
Oct 15 Javascript
jquery ajax属性async(同步异步)示例
Nov 05 Javascript
JS组件Bootstrap Select2使用方法解析
May 30 Javascript
AngularJS的ng Http Request与response格式转换方法
Nov 07 Javascript
canvas实现简易的圆环进度条效果
Feb 28 Javascript
Vue实现购物车功能
Apr 27 Javascript
Node接收电子邮件的实例代码
Jul 21 Javascript
基于vue的tab-list类目切换商品列表组件的示例代码
Feb 14 Javascript
详解Vue 单文件组件的三种写法
Feb 19 Javascript
jQuery实现简单全选框
Sep 13 jQuery
Angular模版驱动表单的使用总结
May 05 #Javascript
浅谈Angular HttpClient简单入门
May 04 #Javascript
Vue项目全局配置微信分享思路详解
May 04 #Javascript
vue嵌套路由与404重定向实现方法分析
May 04 #Javascript
Vue.js最佳实践(五招助你成为vuejs大师)
May 04 #Javascript
详解使用jQuery.i18n.properties实现js国际化
May 04 #jQuery
node实现的爬虫功能示例
May 04 #Javascript
You might like
PHP判断一个gif图片是否为动态图片的方法
2014/11/19 PHP
php类中的$this,static,final,const,self这几个关键字使用方法
2015/12/14 PHP
CodeIgniter多语言实现方法详解
2016/01/20 PHP
jQuery - css() 方法示例详解
2014/01/16 Javascript
javascript 中that的含义示例介绍
2014/05/14 Javascript
jQuery学习笔记之toArray()
2014/06/09 Javascript
javascript中返回顶部按钮的实现
2015/05/05 Javascript
javascript瀑布流布局实现方法详解
2016/02/17 Javascript
AngularJS过滤器filter用法实例分析
2016/11/04 Javascript
学习vue.js条件渲染
2016/12/03 Javascript
JavaScript装饰器函数(Decorator)实例详解
2017/03/30 Javascript
vue中的计算属性的使用和vue实例的方法示例
2017/12/04 Javascript
Angular通过指令动态添加组件问题
2018/07/09 Javascript
JavaScript实现打砖块游戏
2020/02/25 Javascript
angular共享依赖的解决方案分享
2020/10/15 Javascript
在Vue中使用Echarts可视化库的完整步骤记录
2020/11/18 Vue.js
在vue中动态修改css其中一个属性值操作
2020/12/07 Vue.js
[09:13]DOTA2-DPC中国联赛 正赛 Ehome vs Magma 选手采访 1月19日
2021/03/11 DOTA
在Python中使用元类的教程
2015/04/28 Python
Python中的super()方法使用简介
2015/08/14 Python
Python实现的多叉树寻找最短路径算法示例
2018/07/30 Python
python字符串替换re.sub()方法解析
2019/09/18 Python
python爬虫模拟浏览器的两种方法实例分析
2019/12/09 Python
Python利用pip安装tar.gz格式的离线资源包
2020/09/14 Python
python xlsxwriter模块的使用
2020/12/24 Python
HTML5 Video/Audio播放本地文件示例介绍
2013/11/18 HTML / CSS
Roots加拿大官网:加拿大休闲服饰品牌
2016/10/24 全球购物
西班牙用户之间买卖视频游戏的平台:Wakkap
2020/03/21 全球购物
俄罗斯最大的香水和化妆品网上商店:Randewoo
2020/11/05 全球购物
店长岗位职责
2013/11/21 职场文书
身边的榜样活动方案
2014/08/20 职场文书
党员先进性教育整改措施
2014/09/18 职场文书
党的群众路线教育实践活动查摆问题及整改措施
2014/10/10 职场文书
python 常用的异步框架汇总整理
2021/06/18 Python
vue组件冲突之引用另一个组件出现组件不显示的问题
2022/04/13 Vue.js
Windows server 2012搭建FTP服务器
2022/04/29 Servers