這篇文章給大家分享的是有關(guān)怎樣提升vue.js中大型數(shù)據(jù)的性能的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)專注于陽谷企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城建設(shè)。陽谷網(wǎng)站建設(shè)公司,為陽谷等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站策劃,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)VueDose的所有的文章都非常的簡潔,我相信人們在這種格式下更容易找到有用的東西。所以,讓我們直奔主題。
通常我們需要獲取對象數(shù)據(jù),比如用戶,項目,文章,等等等等·····
有時,我們甚至不需要修改它們,只是為了展示它們或在(a.k.a. Vuex)中存貯它們的全局狀態(tài)。那么獲取這個數(shù)據(jù)的簡單代碼如下:
export default { data: () => ({ users: {} }), async created() { const users = await axios.get("/api/users"); this.users = users; } };
Vue會自動循環(huán)數(shù)組的每個對象,并對每個一級屬性進行響應(yīng)。
對于大型數(shù)組對象來說這是一個昂貴的做法。是的,有時候你可以把這些數(shù)據(jù)分頁,但是,其他人就能從前端拿到你整個數(shù)據(jù)。
谷歌地圖標(biāo)記通常就是這種情況,事實上它們是一個巨大的對象。
所以,在這些情況下,如果能夠阻止Vue對這個數(shù)據(jù)的反應(yīng)機制,我們可以獲得一些性能上的提升。我們可以在添加到組件之前使用 Object.freeze 來處理數(shù)據(jù)實現(xiàn)這一點:
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); } };
順便說一下,如果你想要修改數(shù)組,你可以創(chuàng)建一個新數(shù)組來實現(xiàn)。列如,在原有上添加數(shù)據(jù)項,你可以這樣做:
state.users = Object.freeze([...state.users, user]);
你想知道性能提升多少?我們會在下一篇文章看到它,所以,請繼續(xù)關(guān)注。
今天就到這里了!希望你會喜歡這第一篇文章
理解
這篇文章說的內(nèi)容主要是如果你確定數(shù)據(jù)是純展示用的,如果你一次請求的數(shù)據(jù)特別大的話,那么可以用 Object.freeze 來凍結(jié)你的數(shù)據(jù),凍結(jié)了數(shù)據(jù)之后會阻止Vue的默認響應(yīng)機制,會提高Vue的性能。
Object.freeze()的定義:
Object.freeze() 方法可以凍結(jié)一個對象。一個被凍結(jié)的對象再也不能被修改;凍結(jié)了一個對象則不能向這個對象添加新的屬性,不能刪除已有屬性,不能修改該對象已有屬性的可枚舉性、可配置性、可寫性,以及不能修改已有屬性的值。此外,凍結(jié)一個對象后該對象的原型也不能被修改。freeze() 返回和傳入的參數(shù)相同的對象。
感謝各位的閱讀!關(guān)于“怎樣提升vue.js中大型數(shù)據(jù)的性能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!