国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

如何提升vue.js中大型數據的性能

2019-11-19 11:17:42
字體:
來源:轉載
供稿:網友

你好!歡迎大家訪問VueDose的第一篇文章!我們在VueDose中開始冒險吧,你會喜歡這些對你有幫助的小技巧。

VueDose的所有的文章都非常的簡潔,我相信人們在這種格式下更容易找到有用的東西。所以,讓我們直奔主題。

通常我們需要獲取對象數據,比如用戶,項目,文章,等等等等?????

有時,我們甚至不需要修改它們,只是為了展示它們或在(a.k.a. Vuex)中存貯它們的全局狀態。那么獲取這個數據的簡單代碼如下:

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

Vue會自動循環數組的每個對象,并對每個一級屬性進行響應。

對于大型數組對象來說這是一個昂貴的做法。是的,有時候你可以把這些數據分頁,但是,其他人就能從前端拿到你整個數據。

谷歌地圖標記通常就是這種情況,事實上它們是一個巨大的對象。

所以,在這些情況下,如果能夠阻止Vue對這個數據的反應機制,我們可以獲得一些性能上的提升。我們可以在添加到組件之前使用 Object.freeze 來處理數據實現這一點:

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

這個也同樣適用于 Vuex:

const mutations = {setUsers(state, users) {state.users = Object.freeze(users);}};

順便說一下,如果你想要修改數組,你可以創建一個新數組來實現。列如,在原有上添加數據項,你可以這樣做:

state.users = Object.freeze([...state.users, user]);

你想知道性能提升多少?我們會在下一篇文章看到它,所以,請繼續關注。

今天就到這里了!希望你會喜歡這第一篇文章

理解

這篇文章說的內容主要是如果你確定數據是純展示用的,如果你一次請求的數據特別大的話,那么可以用 Object.freeze 來凍結你的數據,凍結了數據之后會阻止Vue的默認響應機制,會提高Vue的性能。

Object.freeze()的定義:

Object.freeze() 方法可以凍結一個對象。一個被凍結的對象再也不能被修改;凍結了一個對象則不能向這個對象添加新的屬性,不能刪除已有屬性,不能修改該對象已有屬性的可枚舉性、可配置性、可寫性,以及不能修改已有屬性的值。此外,凍結一個對象后該對象的原型也不能被修改。freeze() 返回和傳入的參數相同的對象。

結尾

水平有限,難免有錯漏之處,望各位大大輕噴的同時能夠指出,跪謝!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 河间市| 安多县| 晋城| 莲花县| 兴国县| 双牌县| 明水县| 博客| 云南省| 巴中市| 宣武区| 靖安县| 兴海县| 大安市| 津市市| 潮州市| 辉县市| 伊春市| 嘉荫县| 大姚县| 甘孜县| 开原市| 南华县| 沛县| 通海县| 九江县| 社旗县| 丹东市| 铜陵市| 竹山县| 宿松县| 江阴市| 怀宁县| 桃园市| 准格尔旗| 韶关市| 成都市| 嘉荫县| 抚松县| 巴南区| 木兰县|