Vue列表页渲染优化详解

发布时间 - 2026-01-11 02:29:30    点击率:

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


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Python函数文档自动校验_规范解析【教程】  Laravel如何使用查询构建器?(Query Builder高级用法)  如何在云虚拟主机上快速搭建个人网站?  如何快速上传自定义模板至建站之星?  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  Python数据仓库与ETL构建实战_Airflow调度流程详解  利用JavaScript实现拖拽改变元素大小  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  如何用5美元大硬盘VPS安全高效搭建个人网站?  如何安全更换建站之星模板并保留数据?  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  如何快速建站并高效导出源代码?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Laravel如何使用Service Container和依赖注入?(代码示例)  如何快速重置建站主机并恢复默认配置?  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  JavaScript模板引擎Template.js使用详解  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel如何配置任务调度?(Cron Job示例)  网站制作软件有哪些,制图软件有哪些?  Laravel如何创建自定义Facades?(详细步骤)  Windows Hello人脸识别突然无法使用  Laravel如何使用.env文件管理环境变量?(最佳实践)  Laravel如何实现事件和监听器?(Event & Listener实战)  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  如何快速搭建高效简练网站?  高防服务器租用首荐平台,企业级优惠套餐快速部署  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  linux top下的 minerd 木马清除方法  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  Linux系统命令中screen命令详解  如何快速搭建虚拟主机网站?新手必看指南  jquery插件bootstrapValidator表单验证详解  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  图册素材网站设计制作软件,图册的导出方式有几种?  米侠浏览器网页背景异常怎么办 米侠显示修复  Laravel如何处理异常和错误?(Handler示例)  晋江文学城电脑版官网 晋江文学城网页版直接进入  Android仿QQ列表左滑删除操作  如何获取上海专业网站定制建站电话?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  如何用免费手机建站系统零基础打造专业网站?