全网整合营销服务商

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

免费咨询热线: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前端高效开发之列表渲染指令  # 喜马拉雅  # 会对  # 的是  # 春江花月夜  # 会有  # 还可以  # 不需要  # 如有  # 两种  # 将其  # 数据结构  # 可以直接  # 可以使用  # 会给  # 绑定  # 需要注意  # 具体内容  # 大家多多  # 每一项  # 组中 


相关文章: 长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  建站之星logo尺寸如何设置最合适?  如何高效利用200m空间完成建站?  建站之星微信建站一键生成小程序+多端营销系统  建站主机是什么?如何选择适合的建站主机?  常州自助建站工具推荐:低成本搭建与模板选择技巧  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  如何解决VPS建站LNMP环境配置常见问题?  中山网站制作网页,中山新生登记系统登记流程?  如何选择服务器才能高效搭建专属网站?  如何用花生壳三步快速搭建专属网站?  建站VPS能否同时实现高效与安全翻墙?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  如何获取免费开源的自助建站系统源码?  建站主机是否等同于虚拟主机?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  h5在线制作网站电脑版下载,h5网页制作软件?  已有域名和空间,如何快速搭建网站?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  如何撰写建站申请书?关键要点有哪些?  如何获取上海专业网站定制建站电话?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  代刷网站制作软件,别人代刷火车票靠谱吗?  内网网站制作软件,内网的网站如何发布到外网?  如何基于PHP生成高效IDC网络公司建站源码?  如何解决ASP生成WAP建站中文乱码问题?  定制建站如何定义?其核心优势是什么?  建站之星后台管理如何实现高效配置?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  如何高效搭建专业期货交易平台网站?  如何通过老薛主机一键快速建站?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  制作企业网站建设方案,怎样建设一个公司网站?  如何快速搭建FTP站点实现文件共享?  ppt制作免费网站有哪些,ppt模板免费下载网站?  威客平台建站流程解析:高效搭建教程与设计优化方案  如何在景安服务器上快速搭建个人网站?  如何快速生成ASP一键建站模板并优化安全性?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  七夕网站制作视频,七夕大促活动怎么报名?  高端建站三要素:定制模板、企业官网与响应式设计优化  建站之星多图banner生成与模板自定义指南  如何在IIS服务器上快速部署高效网站?  C#怎么使用委托和事件 C# delegate与event编程方法  微信小程序 五星评分(包括半颗星评分)实例代码  沈阳制作网站公司排名,沈阳装饰协会官方网站? 

您的项目需求

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