溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎樣提升vue.js中大型數(shù)據(jù)的性能

發(fā)布時(shí)間:2021-02-04 11:16:28 來(lái)源:億速云 閱讀:202 作者:小新 欄目:web開(kāi)發(fā)

這篇文章給大家分享的是有關(guān)怎樣提升vue.js中大型數(shù)據(jù)的性能的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

VueDose的所有的文章都非常的簡(jiǎn)潔,我相信人們?cè)谶@種格式下更容易找到有用的東西。所以,讓我們直奔主題。

通常我們需要獲取對(duì)象數(shù)據(jù),比如用戶,項(xiàng)目,文章,等等等等·····

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

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

Vue會(huì)自動(dòng)循環(huán)數(shù)組的每個(gè)對(duì)象,并對(duì)每個(gè)一級(jí)屬性進(jìn)行響應(yīng)。

對(duì)于大型數(shù)組對(duì)象來(lái)說(shuō)這是一個(gè)昂貴的做法。是的,有時(shí)候你可以把這些數(shù)據(jù)分頁(yè),但是,其他人就能從前端拿到你整個(gè)數(shù)據(jù)。

谷歌地圖標(biāo)記通常就是這種情況,事實(shí)上它們是一個(gè)巨大的對(duì)象。

所以,在這些情況下,如果能夠阻止Vue對(duì)這個(gè)數(shù)據(jù)的反應(yīng)機(jī)制,我們可以獲得一些性能上的提升。我們可以在添加到組件之前使用 Object.freeze 來(lái)處理數(shù)據(jù)實(shí)現(xiàn)這一點(diǎn):

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

這個(gè)也同樣適用于 Vuex:

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

順便說(shuō)一下,如果你想要修改數(shù)組,你可以創(chuàng)建一個(gè)新數(shù)組來(lái)實(shí)現(xiàn)。列如,在原有上添加數(shù)據(jù)項(xiàng),你可以這樣做:

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

你想知道性能提升多少?我們會(huì)在下一篇文章看到它,所以,請(qǐng)繼續(xù)關(guān)注。

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

理解

這篇文章說(shuō)的內(nèi)容主要是如果你確定數(shù)據(jù)是純展示用的,如果你一次請(qǐng)求的數(shù)據(jù)特別大的話,那么可以用 Object.freeze 來(lái)凍結(jié)你的數(shù)據(jù),凍結(jié)了數(shù)據(jù)之后會(huì)阻止Vue的默認(rèn)響應(yīng)機(jī)制,會(huì)提高Vue的性能。

Object.freeze()的定義:

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

感謝各位的閱讀!關(guān)于“怎樣提升vue.js中大型數(shù)據(jù)的性能”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI