全网整合营销服务商

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

免费咨询热线: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在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  北京网站制作的公司有哪些,北京白云观官方网站?  微信h5制作网站有哪些,免费微信H5页面制作工具?  安云自助建站系统如何快速提升SEO排名?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  如何通过建站之星自助学习解决操作问题?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  如何在建站之星网店版论坛获取技术支持?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何挑选高效建站主机与优质域名?  太原网站制作公司有哪些,网约车营运证查询官网?  如何用搬瓦工VPS快速搭建个人网站?  如何快速启动建站代理加盟业务?  定制建站方案优化指南:企业官网开发与建站费用解析  如何通过虚拟机搭建网站?详细步骤解析  c# 服务器GC和工作站GC的区别和设置  如何通过VPS搭建网站快速盈利?  建站主机如何选?性能与价格怎样平衡?  如何在Golang中使用replace替换模块_指定本地或远程路径  如何用IIS7快速搭建并优化网站站点?  济南专业网站制作公司,济南信息工程学校怎么样?  如何挑选优质建站一级代理提升网站排名?  宝塔面板如何快速创建新站点?  如何快速搭建高效服务器建站系统?  如何在局域网内绑定自建网站域名?  如何通过二级域名建站提升品牌影响力?  建站之星安装失败:服务器环境不兼容?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  如何高效利用200m空间完成建站?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  如何选择香港主机高效搭建外贸独立站?  营销式网站制作方案,销售哪个网站招聘效果最好?  如何在宝塔面板中修改默认建站目录?  移民网站制作流程,怎么看加拿大移民官网?  网站设计制作企业有哪些,抖音官网主页怎么设置?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  建站为何优先选择香港服务器?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  如何高效配置IIS服务器搭建网站?  南宁网站建设制作定制,南宁网站建设可以定制吗?  建站之星如何实现PC+手机+微信网站五合一建站?  nginx修改上传文件大小限制的方法  高防服务器租用首荐平台,企业级优惠套餐快速部署  建站之星导航配置指南:自助建站与SEO优化全解析 

您的项目需求

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