欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Vue列表頁渲染優(yōu)化的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下Vue列表頁渲染優(yōu)化的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)公司是專業(yè)的西秀網(wǎng)站建設(shè)公司,西秀接單;提供成都網(wǎng)站制作、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行西秀網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

想法

初始化時(shí),vue會(huì)對data做getter、setter改造,在現(xiàn)代瀏覽器里,雖然JS已經(jīng)足夠快,但仍然有優(yōu)化空間。

列表頁的數(shù)據(jù)結(jié)構(gòu)為:

list: [
    // 每一項(xiàng)有不同的來源,不同來源的數(shù)據(jù)都不同,因此放到一個(gè)數(shù)組里
    [{
      sourceId: 'xmla', // 來源的唯一標(biāo)識(shí)
      id: 3001, // 資源的唯一標(biāo)識(shí)
      source: '喜馬拉雅', // 來源
      title: '昆曲之牡丹亭',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是專輯
      hot: 1345,
      anchor: '青雪'
    }, {
      sourceId: 'xmla', // 來源的唯一標(biāo)識(shí)
      id: 3005, // 資源的唯一標(biāo)識(shí)
      source: '手機(jī)百度', // 來源
      title: '昆曲之牡丹亭',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是專輯
      hot: 1345,
      anchor: '青雪'
    }],
    [{
      sourceId: 'xmla',
      id: 3002, // 資源的唯一標(biāo)識(shí)
      source: '喜馬拉雅', // 來源
      title: '昆曲之春江花月夜',
      imageUrl: 'http://x.baidu.com/x.gif',
      album: 0, // 是否是專輯
      hot: 1345,
      anchor: '青雪'
    }],
  ]
}

Vue會(huì)給數(shù)組中的每個(gè)值設(shè)置getter和setter來監(jiān)聽它們的變動(dòng)

但其實(shí)列表數(shù)據(jù)是不會(huì)發(fā)生變化的,這些操作是多余的。

方法一:使用Object.freeze()

Object.freeze()是ES5新增的API,用來凍結(jié)一個(gè)對象,禁止對象被修改。vue 1.0.18+以后,不會(huì)對已凍結(jié)的data做getter、setter轉(zhuǎn)換。

如果確保某個(gè)data不需要跟蹤依賴,可以使用Object.freeze將其凍結(jié)。需要注意的是,被凍結(jié)的是對象的值,仍然可以將引用整個(gè)替換調(diào)??聪旅胬樱?/p>

<p v-for="item in list">{{ item.value }}</p>
new Vue({
  data: {
    // vue不會(huì)對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沒有了。

方法二:傳string方法

由于從后端取回的數(shù)據(jù)本身為字符串,不進(jìn)行JSON.parse()直接存在state中,即可阻止Vue的改造。
使用時(shí),在頁面組件中引入字符串,JSON.parse()后可以直接賦值給this.XXX,如有需要還可以進(jìn)一步子組件。

this.test = {
  a:{
    c:1,
    d:2
  },
  b:2
}
<list-item :test="test.a"></list-item>

以上是“Vue列表頁渲染優(yōu)化的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

分享文章:Vue列表頁渲染優(yōu)化的示例分析-創(chuàng)新互聯(lián)
本文來源:http://chinadenli.net/article28/cdpecp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、網(wǎng)站排名、微信小程序移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司