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

溫馨提示×

溫馨提示×

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

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

Vue列表頁渲染優化的示例分析

發布時間:2021-08-13 10:21:27 來源:億速云 閱讀:108 作者:小新 欄目:web開發

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

想法

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

列表頁的數據結構為:

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來監聽它們的變動

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

方法一:使用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進行狀態管理時,應當在給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列表頁渲染優化的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

vue
AI

瑞丽市| 启东市| 陆良县| 崇义县| 四平市| 娄烦县| 惠州市| 伊春市| 彭阳县| 樟树市| 观塘区| 常山县| 城步| 昔阳县| 永兴县| 青河县| 芜湖市| 巴青县| 岗巴县| 双江| 曲周县| 石楼县| 芦溪县| 安阳县| 南皮县| 江西省| 青州市| 珠海市| 远安县| 三亚市| 盐津县| 高密市| 苏州市| 班戈县| 乌拉特前旗| 桐柏县| 耿马| 安丘市| 山东| 武汉市| 乌恰县|