Vue列表页渲染优化详解

网友投稿 270 2023-04-25


Vue列表页渲染优化详解

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

想法

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

列表页的数据结构为:

list: [

// 每一项有不同的来源,不同来源的数据都不同,因此放到一个数组里

[{

sourceId: 'xmla', // 来源的唯一标识

id: 3001, // 资源的唯一标识

source: '喜马拉雅', // 来GECoFYerAq源

title: GECoFYerAq'昆曲之牡丹亭',

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将其冻结。需要注意的是,被冻结的是对象的值,仍然可以将引用整个替换调。看下面例子:

{{ item.value }}

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

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:vue axios用法教程详解
下一篇:Java利用Redis实现消息队列的示例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~