加速vue组件渲染之性能优化


Posted in Javascript onApril 09, 2020

背景

平时在用vue开发后台管理系统的时候,应该会用到大量的table这种组件,正常这种组件我们会在项目里做二次封装,然后针对表头title做参数化配置,如下:

export default {
  data(){
    return {
      tableTitle:[
        {
          label:'省份',
          prop:'prop'
        },
        {
          label:'城市',
          prop:'prop'
        },
        {
          label:'汇总',
          prop:'prop',
          colconfig:[
            {
              label:'下级',
              prop:'prop'
            }
          ]
        }
        ...
      ]
    }
  }
}

此时如果table字段比较多而且是多表头这种的话,数据结构就比较复杂,如果直接写在data里面的话,会在组件初始化时候,对此对象进行递归重写get set属性,源码如下:

function defineReactive(obj,key,val) {
 var dep = new Dep();
 var property = Object.getOwnPropertyDescriptor(obj, key);
 //如果对象被冻结,则直接跳出,不重写 get set方法
 if (property && property.configurable === false) {
  return
 }
 //observe会递归调用defineReactive,去重写对象内层的get set属性
 var childOb = !shallow && observe(val);
 Object.defineProperty(obj, key, {
  enumerable: true,
  configurable: true,
  get: function reactiveGetter () {
  },
  set: function reactiveSetter (newVal) {
  }
 });
}

然而这种静态数据是不需要动态响应的,这样势必会造浪性能浪费,于是我们想办法避免这种不必要的性能浪费。

方案1

此时我们可以用Object.freeze()这个方法对此数据进行冻结,vue组件在对data里的属性拦截时,会判断出被冻结的对象是不可被修改的【如上代码注释】,会直接跳过 get set的操作,这样便可以降低vue组件的render时间,提升页面性能

export default {

data(){
  return {
    tableTitle:Object.freeze(objConfig)
  }
}
}

方案2

把我们不需要动态响应的数据,在created的生命周期里面去定义,这样vue底层就不会拦截到这个属性了

export default {
  created(){
    this.tableTitle = [xxxxx]
  }
}

总结

其实这种场景在开发中经常遇到,比如查询条件有很多selectlist字段,我们也可以把它封装到一个大json里面,然后对其进行避免重写属性,可以降低不少性能开销

到此这篇关于加速vue组件渲染之性能优化的文章就介绍到这了,更多相关vue组件渲染性能优化内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
免费空间广告万能消除代码
Sep 04 Javascript
深入理解Javascript中的循环优化
Nov 09 Javascript
基于jQuery+PHP+Mysql实现在线拍照和在线浏览照片
Sep 06 Javascript
JS上传图片预览插件制作(兼容到IE6)
Aug 07 Javascript
一个可复用的vue分页组件
May 15 Javascript
React Native使用百度Echarts显示图表的示例代码
Nov 07 Javascript
浅谈vue-router2路由参数注意的问题
Nov 08 Javascript
浅谈Webpack自动化构建实践指南
Dec 18 Javascript
小程序ios音频播放没声音问题的解决
Jul 11 Javascript
jQuery 实现倒计时天,时,分,秒功能
Jul 31 jQuery
基于JavaScript实现瀑布流布局
Aug 15 Javascript
es6中let和const的使用方法详解
Feb 24 Javascript
javascript设计模式 ? 抽象工厂模式原理与应用实例分析
Apr 09 #Javascript
javascript设计模式 ? 工厂模式原理与应用实例分析
Apr 09 #Javascript
javascript设计模式 ? 简单工厂模式原理与应用实例分析
Apr 09 #Javascript
javascript设计模式 ? 单例模式原理与应用实例分析
Apr 09 #Javascript
微信小程序纯文本实现@功能
Apr 08 #Javascript
JavaScript 俄罗斯方块游戏实现方法与代码解释
Apr 08 #Javascript
vue与iframe之间的信息交互的实现
Apr 08 #Javascript
You might like
根德Grundig S400/S500/S700电路分析
2021/03/02 无线电
打造计数器DIY三步曲(中)
2006/10/09 PHP
使用网络地址转换实现多服务器负载均衡
2006/10/09 PHP
php数组函数序列之rsort() - 对数组的元素值进行降序排序
2011/11/02 PHP
用Json实现PHP与JavaScript间数据交换的方法详解
2013/06/20 PHP
PHP实现将浏览历史页面网址保存到cookie的方法
2015/01/26 PHP
php判断对象是派生自哪个类的方法
2015/06/20 PHP
PHP引用的调用方法分析
2016/04/25 PHP
基础的prototype.js常用函数及其用法
2007/03/10 Javascript
ExtJs事件机制基本代码模型和流程解析
2010/10/24 Javascript
JS中window.open全屏命令解析及使用示例
2013/12/11 Javascript
JS+CSS实现可以凹陷显示选中单元格的方法
2015/03/02 Javascript
为什么JS中eval处理JSON数据要加括号
2015/04/13 Javascript
Angular的模块化(代码分享)
2016/12/26 Javascript
详解vuelidate 对于vueJs2.0的验证解决方案
2017/03/09 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
Jquery获取radio选中值实例总结
2019/01/17 jQuery
小程序实现短信登录倒计时
2019/07/12 Javascript
对pandas的dataframe绘图并保存的实现方法
2017/08/05 Python
详解python字节码
2018/02/07 Python
python打包压缩、读取指定目录下的指定类型文件
2018/04/12 Python
python版本单链表实现代码
2018/09/28 Python
Python中xml和json格式相互转换操作示例
2018/12/05 Python
python3.x实现base64加密和解密
2019/03/28 Python
python itchat实现调用微信接口的第三方模块方法
2019/06/11 Python
Python 读取用户指令和格式化打印实现解析
2019/09/02 Python
K最近邻算法(KNN)---sklearn+python实现方式
2020/02/24 Python
Python3爬虫中关于Ajax分析方法的总结
2020/07/10 Python
Python监听剪切板实现方法代码实例
2020/11/11 Python
Python Selenium破解滑块验证码最新版(GEETEST95%以上通过率)
2021/01/29 Python
JAVA中运算符的分类及举例
2015/09/12 面试题
商务英语专业应届毕业生求职信
2013/10/28 职场文书
优秀毕业生求职信范文
2014/01/02 职场文书
总经理岗位职责范本
2014/02/02 职场文书
镇创先争优活动总结
2014/08/28 职场文书
golang http使用踩过的坑与填坑指南
2021/04/27 Golang