专栏名称: 程序猿何大叔
前端工程师
目录
相关文章推荐
前端早读课  ·  【第3464期】从初级开发者到高级开发者:借 ... ·  18 小时前  
前端早读课  ·  【图书】零基础开发AI ... ·  2 天前  
前端早读课  ·  【第3462期】7 分钟深度理解柯里化 ·  2 天前  
51好读  ›  专栏  ›  程序猿何大叔

【译】Vue 的小奇技(第一篇):提高大型数据列表的性能

程序猿何大叔  · 掘金  · 前端  · 2019-01-25 03:45

正文

阅读 442

【译】Vue 的小奇技(第一篇):提高大型数据列表的性能

特别声明:本文是作者 Alex Jover 发布在 VueDose 上的一个系列。

版权归作者所有。

译者在翻译前已经和作者沟通得到了翻译整个系列的授权。

为了不影响大家阅读,获得授权的记录会放在本文的最后。

嗨,大家好!欢迎来到 VueDose 的第一篇文章。我已经准备好在 VueDose 上开启这段旅程,来帮助像你一样的开发者们来学习一些厉害的技巧。

首先,在 VueDose 上发布的文章都是很简洁明了的,因为我相信这样的行文风格对于读者来说会更有帮助,所以我们现在就直接开始吧。

正文内容

通常我们在应用中会请求一些列表数据,比如说用户列表、商品列表、文章列表等等......

而且有时候,我们并不会去修改这些请求回来的列表数据,而只是单纯地去展示它们,或者是把它们保存在全局状态管理器里面(又称之为 Vuex)。请求数据列表的示意代码如下所示:

export default {
  data: () => ({
    users: {}
  }),
  async created() {
    const users = await axios.get("/api/users");
    this.users = users;
  }
};
复制代码

Vue 在默认情况下,会将数组 this.users 中的,所有对象的第一层属性设置为响应式数据。

这对于大型的对象数组来说,性能成本非常的高。没错,的确有时候列表数据是有分页的,但总会有一些情况下,是没有进行分页,继而在前端展示的。

一个实际的例子就是谷歌地图的标记点 markers 列表数据,这就是一个拥有很多对象的大型数组。

所以,在一些特定的情况下,如果我们能够阻止 Vue 将这些列表数据设置为响应式的,那么我们就可以为项目带来一些性能上的提升。实际上我们就是可以做到的,通过用 Object.freeze 方法,将获取到的列表数据在赋值给组件之前,进行冻结:

export default {
  data: () => ({
    users: {}
  }),
  async created() {
    const users = await axios.get("/api/users");
    this.users = Object.freeze(users);
  }
};
复制代码

记住,同样地可以应用到 Vuex 实践中:

const






请到「今天看啥」查看全文