91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎樣提升vue.js中大型數據的性能

發布時間:2021-02-04 11:16:28 來源:億速云 閱讀:203 作者:小新 欄目:web開發

這篇文章給大家分享的是有關怎樣提升vue.js中大型數據的性能的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

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() 返回和傳入的參數相同的對象。

感謝各位的閱讀!關于“怎樣提升vue.js中大型數據的性能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

轮台县| 柏乡县| 台湾省| 花莲县| 多伦县| 牟定县| 尉氏县| 根河市| 桑植县| 五寨县| 伊金霍洛旗| 瑞安市| 徐闻县| 尉犁县| 龙口市| 奎屯市| 南丰县| 察隅县| 葵青区| 金坛市| 陕西省| 忻城县| 台山市| 通山县| 长乐市| 洮南市| 福鼎市| 杨浦区| 海林市| 昌江| 西平县| 襄城县| 南陵县| 河西区| 朝阳市| 黄陵县| 揭东县| 报价| 定陶县| 久治县| 双城市|