Vue列表頁(yè)渲染優(yōu)化詳解
vue列表頁(yè)渲染優(yōu)化,具體內(nèi)容如下
想法
初始化時(shí),vue會(huì)對(duì)data做getter、setter改造,在現(xiàn)代瀏覽器里,雖然JS已經(jīng)足夠快,但仍然有優(yōu)化空間。
列表頁(yè)的數(shù)據(jù)結(jié)構(gòu)為:
list: [ // 每一項(xiàng)有不同的來(lái)源,不同來(lái)源的數(shù)據(jù)都不同,因此放到一個(gè)數(shù)組里 [{ sourceId: 'xmla', // 來(lái)源的唯一標(biāo)識(shí) id: 3001, // 資源的唯一標(biāo)識(shí) source: '喜馬拉雅', // 來(lái)源 title: '昆曲之牡丹亭', imageUrl: 'http://x.baidu.com/x.gif', album: 0, // 是否是專(zhuān)輯 hot: 1345, anchor: '青雪' }, { sourceId: 'xmla', // 來(lái)源的唯一標(biāo)識(shí) id: 3005, // 資源的唯一標(biāo)識(shí) source: '手機(jī)百度', // 來(lái)源 title: '昆曲之牡丹亭', imageUrl: 'http://x.baidu.com/x.gif', album: 0, // 是否是專(zhuān)輯 hot: 1345, anchor: '青雪' }], [{ sourceId: 'xmla', id: 3002, // 資源的唯一標(biāo)識(shí) source: '喜馬拉雅', // 來(lái)源 title: '昆曲之春江花月夜', imageUrl: 'http://x.baidu.com/x.gif', album: 0, // 是否是專(zhuān)輯 hot: 1345, anchor: '青雪' }], ] }
Vue會(huì)給數(shù)組中的每個(gè)值設(shè)置getter和setter來(lái)監(jiān)聽(tīng)它們的變動(dòng)
但其實(shí)列表數(shù)據(jù)是不會(huì)發(fā)生變化的,這些操作是多余的。
方法一:使用Object.freeze()
Object.freeze()是ES5新增的API,用來(lái)凍結(jié)一個(gè)對(duì)象,禁止對(duì)象被修改。vue 1.0.18+以后,不會(huì)對(duì)已凍結(jié)的data做getter、setter轉(zhuǎn)換。
如果確保某個(gè)data不需要跟蹤依賴(lài),可以使用Object.freeze將其凍結(jié)。需要注意的是,被凍結(jié)的是對(duì)象的值,仍然可以將引用整個(gè)替換調(diào)。看下面例子:
<p v-for="item in list">{{ item.value }}</p>
new Vue({ data: { // vue不會(huì)對(duì)list里的object做getter、setter綁定 list: Object.freeze([ { value: 1 }, { value: 2 } ]) }, created () { // 界面不會(huì)有響應(yīng) this.list[0].value = 100; // 下面兩種做法,界面都會(huì)響應(yīng) this.list = [ { value: 100 }, { value: 200 } ]; this.list = Object.freeze([ { value: 100 }, { value: 200 } ]); } })
當(dāng)使用Vuex進(jìn)行狀態(tài)管理時(shí),應(yīng)當(dāng)在給state.xxx賦值前使用Object.freeze():
[LIST_INIT](state, {list}) { Object.freeze(list); state.list = list; },
getter和setter沒(méi)有了。
方法二:傳string方法
由于從后端取回的數(shù)據(jù)本身為字符串,不進(jìn)行JSON.parse()直接存在state中,即可阻止Vue的改造。
使用時(shí),在頁(yè)面組件中引入字符串,JSON.parse()后可以直接賦值給this.XXX,如有需要還可以進(jìn)一步子組件。
this.test = { a:{ c:1, d:2 }, b:2 }
<list-item :test="test.a"></list-item>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vuejs第一篇之入門(mén)教程詳解(單向綁定、雙向綁定、列表渲染、響應(yīng)函數(shù))
- VUEJS實(shí)戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表(1)
- 深入理解Vue 的條件渲染和列表渲染
- 詳解vuejs之v-for列表渲染
- vue.js基于v-for實(shí)現(xiàn)批量渲染 Json數(shù)組對(duì)象列表數(shù)據(jù)示例
- Vue.JS入門(mén)教程之列表渲染
- Vue.js學(xué)習(xí)教程之列表渲染詳解
- Vue.js列表渲染綁定jQuery插件的正確姿勢(shì)
- Vue 監(jiān)聽(tīng)列表item渲染事件方法
- Vue前端高效開(kāi)發(fā)之列表渲染指令
相關(guān)文章
vue中響應(yīng)式布局如何將字體大小改成自適應(yīng)
這篇文章主要介紹了vue中響應(yīng)式布局如何將字體大小改成自適應(yīng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09vue-devtools?開(kāi)發(fā)工具插件之支持vue3?chrome?瀏覽器插件
這篇文章主要介紹了vue-devtools?開(kāi)發(fā)工具插件之支持vue3?chrome?瀏覽器插件,用這個(gè)版本主要是為了支持vue3?推薦直接下載,文中給大家提供了下載地址,感興趣的朋友跟隨小編一起看看吧2022-01-01vue的異步數(shù)據(jù)更新機(jī)制與$nextTick用法解讀
這篇文章主要介紹了vue的異步數(shù)據(jù)更新機(jī)制與$nextTick用法解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03關(guān)于VanCascader默認(rèn)值(地址code轉(zhuǎn)換)
這篇文章主要介紹了關(guān)于VanCascader默認(rèn)值(地址code轉(zhuǎn)換),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07vue 解除鼠標(biāo)的監(jiān)聽(tīng)事件的方法
這篇文章主要介紹了vue 解除鼠標(biāo)的監(jiān)聽(tīng)事件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11el-table樹(shù)形表格表單驗(yàn)證(列表生成序號(hào))
這篇文章主要介紹了el-table樹(shù)形表格表單驗(yàn)證(列表生成序號(hào)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05