亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue列表頁渲染優(yōu)化詳解

 更新時間:2017年07月24日 14:11:49   作者:zxy85189122  
這篇文章主要為大家詳細介紹了Vue列表頁渲染優(yōu)化的操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下

vue列表頁渲染優(yōu)化,具體內容如下

想法

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

列表頁的數據結構為:

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

Vue會給數組中的每個值設置getter和setter來監(jiān)聽它們的變動

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

方法一:使用Object.freeze()

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

如果確保某個data不需要跟蹤依賴,可以使用Object.freeze將其凍結。需要注意的是,被凍結的是對象的值,仍然可以將引用整個替換調。看下面例子:

<p v-for="item in list">{{ item.value }}</p>
new Vue({
  data: {
    // vue不會對list里的object做getter、setter綁定
    list: Object.freeze([
      { value: 1 },
      { value: 2 }
    ])
  },
  created () {
    // 界面不會有響應
    this.list[0].value = 100;

    // 下面兩種做法,界面都會響應
    this.list = [
      { value: 100 },
      { value: 200 }
    ];
    this.list = Object.freeze([
      { value: 100 },
      { value: 200 }
    ]);
  }
})

當使用Vuex進行狀態(tài)管理時,應當在給state.xxx賦值前使用Object.freeze():

[LIST_INIT](state, {list}) {
  Object.freeze(list);
  state.list = list;
},

getter和setter沒有了。

方法二:傳string方法

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

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

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

相關文章

  • vue中響應式布局如何將字體大小改成自適應

    vue中響應式布局如何將字體大小改成自適應

    這篇文章主要介紹了vue中響應式布局如何將字體大小改成自適應,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue之debounce屬性被移除及處理詳解

    vue之debounce屬性被移除及處理詳解

    今天小編就為大家分享一篇vue之debounce屬性被移除及處理詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue-devtools?開發(fā)工具插件之支持vue3?chrome?瀏覽器插件

    vue-devtools?開發(fā)工具插件之支持vue3?chrome?瀏覽器插件

    這篇文章主要介紹了vue-devtools?開發(fā)工具插件之支持vue3?chrome?瀏覽器插件,用這個版本主要是為了支持vue3?推薦直接下載,文中給大家提供了下載地址,感興趣的朋友跟隨小編一起看看吧
    2022-01-01
  • vue的異步數據更新機制與$nextTick用法解讀

    vue的異步數據更新機制與$nextTick用法解讀

    這篇文章主要介紹了vue的異步數據更新機制與$nextTick用法解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue單選按鈕,選中如何改變其當前按鈕顏色

    vue單選按鈕,選中如何改變其當前按鈕顏色

    這篇文章主要介紹了vue單選按鈕,選中如何改變其當前按鈕顏色。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue的自定義事件之組件通信工具詳解

    Vue的自定義事件之組件通信工具詳解

    這篇文章主要介紹了Vue的自定義事件之組件通信工具詳解,Vue的自定義事件(Custom Events)是一種強大的工具,用于實現組件之間的通信和數據傳遞,本文將深入探討什么是Vue的自定義事件,以及如何自定義和使用它們,需要的朋友可以參考下
    2023-10-10
  • Vue中的computed屬性詳解

    Vue中的computed屬性詳解

    這篇文章主要為大家介紹了Vue中的computed屬性,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • 關于VanCascader默認值(地址code轉換)

    關于VanCascader默認值(地址code轉換)

    這篇文章主要介紹了關于VanCascader默認值(地址code轉換),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue 解除鼠標的監(jiān)聽事件的方法

    vue 解除鼠標的監(jiān)聽事件的方法

    這篇文章主要介紹了vue 解除鼠標的監(jiān)聽事件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • el-table樹形表格表單驗證(列表生成序號)

    el-table樹形表格表單驗證(列表生成序號)

    這篇文章主要介紹了el-table樹形表格表單驗證(列表生成序號),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05

最新評論