全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Vue列表页渲染优化详解

vue列表页渲染优化,具体内容如下

想法

初始化时,vue会对data做getter、setter改造,在现代浏览器里,虽然JS已经足够快,但仍然有优化空间。

列表页的数据结构为:

list: [
    // 每一项有不同的来源,不同来源的数据都不同,因此放到一个数组里
    [{
      sourceId: 'xmla', // 来源的唯一标识
      id: 3001, // 资源的唯一标识
      source: '喜马拉雅', // 来源
      title: '昆曲之牡丹亭',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是专辑
      hot: 1345,
      anchor: '青雪'
    }, {
      sourceId: 'xmla', // 来源的唯一标识
      id: 3005, // 资源的唯一标识
      source: '手机百度', // 来源
      title: '昆曲之牡丹亭',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是专辑
      hot: 1345,
      anchor: '青雪'
    }],
    [{
      sourceId: 'xmla',
      id: 3002, // 资源的唯一标识
      source: '喜马拉雅', // 来源
      title: '昆曲之春江花月夜',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是专辑
      hot: 1345,
      anchor: '青雪'
    }],
  ]
}

Vue会给数组中的每个值设置getter和setter来监听它们的变动

但其实列表数据是不会发生变化的,这些操作是多余的。

方法一:使用Object.freeze()

Object.freeze()是ES5新增的API,用来冻结一个对象,禁止对象被修改。vue 1.0.18+以后,不会对已冻结的data做getter、setter转换。

如果确保某个data不需要跟踪依赖,可以使用Object.freeze将其冻结。需要注意的是,被冻结的是对象的值,仍然可以将引用整个替换调。看下面例子:

<p v-for="item in list">{{ item.value }}</p>
new Vue({
  data: {
    // vue不会对list里的object做getter、setter绑定
    list: Object.freeze([
      { value: 1 },
      { value: 2 }
    ])
  },
  created () {
    // 界面不会有响应
    this.list[0].value = 100;

    // 下面两种做法,界面都会响应
    this.list = [
      { value: 100 },
      { value: 200 }
    ];
    this.list = Object.freeze([
      { value: 100 },
      { value: 200 }
    ]);
  }
})

当使用Vuex进行状态管理时,应当在给state.xxx赋值前使用Object.freeze():

[LIST_INIT](state, {list}) {
  Object.freeze(list);
  state.list = list;
},

getter和setter没有了。

方法二:传string方法

由于从后端取回的数据本身为字符串,不进行JSON.parse()直接存在state中,即可阻止Vue的改造。
使用时,在页面组件中引入字符串,JSON.parse()后可以直接赋值给this.XXX,如有需要还可以进一步子组件。

this.test = {
  a:{
    c:1,
    d:2
  },
  b:2
}
<list-item :test="test.a"></list-item>

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


# vue列表页渲染优化  # vue渲染优化  # vue列表页  # Vuejs第一篇之入门教程详解(单向绑定、双向绑定、列表渲染、响应函数)  # VUEJS实战之构建基础并渲染出列表(1)  # 深入理解Vue 的条件渲染和列表渲染  # 详解vuejs之v-for列表渲染  # vue.js基于v-for实现批量渲染 Json数组对象列表数据示例  # Vue.JS入门教程之列表渲染  # Vue.js学习教程之列表渲染详解  # Vue.js列表渲染绑定jQuery插件的正确姿势  # Vue 监听列表item渲染事件方法  # Vue前端高效开发之列表渲染指令  # 喜马拉雅  # 会对  # 的是  # 春江花月夜  # 会有  # 还可以  # 不需要  # 如有  # 两种  # 将其  # 数据结构  # 可以直接  # 可以使用  # 会给  # 绑定  # 需要注意  # 具体内容  # 大家多多  # 每一项  # 组中 


相关文章: 手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  广平建站公司哪家专业可靠?如何选择?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何在Tomcat中配置并部署网站项目?  如何快速搭建高效WAP手机网站?  如何选择PHP开源工具快速搭建网站?  如何快速搭建高效服务器建站系统?  如何通过老薛主机一键快速建站?  宁波自助建站系统如何快速打造专业企业网站?  网站制作说明怎么写,简述网页设计的流程并说明原因?  网站制作报价单模板图片,小松挖机官方网站报价?  Python如何创建带属性的XML节点  如何在景安服务器上快速搭建个人网站?  实例解析Array和String方法  5种Android数据存储方式汇总  高端智能建站公司优选:品牌定制与SEO优化一站式服务  西安大型网站制作公司,西安招聘网站最好的是哪个?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  教学网站制作软件,学习*后期制作的网站有哪些?  如何通过建站之星自助学习解决操作问题?  教程网站设计制作软件,怎么创建自己的一个网站?  C#如何序列化对象为XML XmlSerializer用法  ,网页ppt怎么弄成自己的ppt?  安云自助建站系统如何快速提升SEO排名?  javascript中对象的定义、使用以及对象和原型链操作小结  如何在橙子建站中快速调整背景颜色?  建站主机是否属于云主机类型?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何在腾讯云服务器上快速搭建个人网站?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  大同网页,大同瑞慈医院官网?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  在线教育网站制作平台,山西立德教育官网?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  如何规划企业建站流程的关键步骤?  如何快速生成专业多端适配建站电话?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  韩国服务器如何优化跨境访问实现高效连接?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  建站之星代理费用多少?最新价格详情介绍  香港服务器如何优化才能显著提升网站加载速度? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。