微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vue列表页渲染优化详解

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

想法

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

列表页的数据结构为:

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

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

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

方法一:

使用Object.freeze()

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

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

rush:xhtml;">

rush:js;"> 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():

rush:js;"> [LIST_INIT](state,{list}) { Object.freeze(list); state.list = list; },

getter和setter没有了。

方法二:

传string方法

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

rush:js;"> this.test = { a:{ c:1,d:2 },b:2 }
rush:xhtml;">

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

原文地址:https://www.jb51.cc/vue/37623.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐