Vue列表页渲染优化详解
vue列表页渲染优化,具体内容如下 想法初始化时,vue会对data做getter、setter改造,在现代浏览器里,虽然JS已经足够快,但仍然有优化空间。 列表页的数据结构为: Vue会给数组中的每个值设置getter和setter来监听它们的变动 但其实列表数据是不会发生变化的,这些操作是多余的。 方法一:使用Object.freeze()Object.freeze()是ES5新增的API,用来冻结一个对象,禁止对象被修改。vue 1.0.18+以后,不会对已冻结的data做getter、setter转换。 如果确保某个data不需要跟踪依赖,可以使用Object.freeze将其冻结。需要注意的是,被冻结的是对象的值,仍然可以将引用整个替换调。看下面例子: // 下面两种做法,界面都会响应
this.list = [
{ value: 100 },{ value: 200 }
];
this.list = Object.freeze([
{ value: 100 },{ value: 200 }
]);
} 当使用Vuex进行状态管理时,应当在给state.xxx赋值前使用Object.freeze(): getter和setter没有了。 方法二:传string方法由于从后端取回的数据本身为字符串,不进行JSON.parse()直接存在state中,即可阻止Vue的改造。 使用时,在页面组件中引入字符串,JSON.parse()后可以直接赋值给this.XXX,如有需要还可以进一步子组件。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |