欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3.0中的雙向數(shù)據(jù)綁定方法及優(yōu)缺點

 更新時間:2019年08月01日 16:39:55   作者:智子  
這篇文章主要介紹了vue3.0中的雙向數(shù)據(jù)綁定方法 ,文中通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下

熟悉vue的人都知道在vue2.x之前都是使用object.defineProperty來實現(xiàn)雙向數(shù)據(jù)綁定的

而在vue3.0中這個方法被取代了

1. 為什么要替換Object.defineProperty

替換不是因為不好,是因為有更好的方法使用效率更高

Object.defineProperty的缺點:

1. 在Vue中,Object.defineProperty無法監(jiān)控到數(shù)組下標(biāo)的變化,

導(dǎo)致直接通過數(shù)組的下標(biāo)給數(shù)組設(shè)置值,不能實時響應(yīng)。

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

2. Object.defineProperty只能劫持對象的屬性,因此我們需要對每個對象的每個屬性進(jìn)行遍歷。

Vue里,是通過遞歸以及遍歷data對象來實現(xiàn)對數(shù)據(jù)的監(jiān)控的,

如果屬性值也是對象那么需要深度遍歷,顯然如果能劫持一個完整的對象,不管是對操作性還是性能都會有一個很大的提升。

而要取代它的Proxy有以下兩個優(yōu)點:

1. 可以劫持整個對象,并返回一個新對象
2. 有13種劫持操作

2. 什么是Proxy

Proxy是 ES6 中新增的一個特性,翻譯過來意思是"代理",用在這里表示由它來“代理”某些操作。 Proxy 讓我們能夠以簡潔易懂的方式控制外部對對象的訪問。其功能非常類似于設(shè)計模式中的代理模式。

Proxy 可以理解成,在目標(biāo)對象之前架設(shè)一層“攔截”,外界對該對象的訪問,都必須先通過這層攔截,因此提供了一種機制,可以對外界的訪問進(jìn)行過濾和改寫。

使用 Proxy 的核心優(yōu)點是可以交由它來處理一些非核心邏輯(如:讀取或設(shè)置對象的某些屬性前記錄日志;設(shè)置對象的某些屬性值前,需要驗證;某些屬性的訪問控制等)。 從而可以讓對象只需關(guān)注于核心邏輯,達(dá)到關(guān)注點分離,降低對象復(fù)雜度等目的。

基本用法:

let p = new Proxy(target, handler);

參數(shù):

target: 是用Proxy包裝的被代理對象(可以是任何類型的對象,包括原生數(shù)組,函數(shù),甚至另一個代理)。
handler: 是一個對象,其聲明了代理target 的一些操作,其屬性是當(dāng)執(zhí)行一個操作時定義代理的行為的函數(shù)。

p是Proxy對象,當(dāng)其他操作對p進(jìn)行更改的時候,會執(zhí)行handler對象的方法。Proxy有13種數(shù)據(jù)劫持的操作,常用的handler處理方法:

get: 讀取值,
set: 獲取值,
has: 判斷對象是否擁有該屬性,
construct: 構(gòu)造函數(shù)

舉個例子:

let obj = {};
 let handler = {
  get(target, property) {
  console.log(`${property} 被讀取`);
  return property in target ? target[property] : 3;
  },
  set(target, property, value) {
  console.log(`${property} 被設(shè)置為 ${value}`);
  target[property] = value;
  }
 }
 let p = new Proxy(obj, handler);
 p.name = 'tom' //name 被設(shè)置為 tom
 p.age; //age 被讀取 3

更多的Proxy屬性方法參考MDN Proxy

3. Proxy實現(xiàn)數(shù)據(jù)劫持

observe(data) {
 const that = this;
 let handler = {
  get(target, property) {
   return target[property];
  },
  set(target, key, value) {
   let res = Reflect.set(target, key, value);
   that.subscribe[key].map(item => {
    item.update();
   });
   return res;
  }
 }
 this.$data = new Proxy(data, handler);
}

這段代碼里把代理器返回的對象代理到this.$data,即this.$data是代理后的對象,外部每次對this.$data進(jìn)行操作時,實際上執(zhí)行的是這段代碼里handler對象上的方法。

注:這兒用到了reflect屬性,這也是ES6里面的,不知道的去這兒看看吧。reflect屬性

總結(jié)

以上所述是小編給大家介紹的vue3.0中的雙向數(shù)據(jù)綁定方法及優(yōu)缺點,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • 深入了解Vue2中的的雙端diff算法

    深入了解Vue2中的的雙端diff算法

    雙端Diff在可以解決更多簡單Diff算法處理不了的場景,且比簡單Diff算法性能更好。本文主要來和大家詳細(xì)講講Vue2中的雙端diff算法的實現(xiàn)與使用,需要的可以參考一下
    2023-02-02
  • Element輸入框帶歷史查詢記錄的實現(xiàn)示例

    Element輸入框帶歷史查詢記錄的實現(xiàn)示例

    這篇文章主要介紹了Element輸入框帶歷史查詢記錄的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue-cli的webpack模板項目配置文件分析

    vue-cli的webpack模板項目配置文件分析

    本篇文章主要對vue-cli的webpack模板項目配置文件進(jìn)行分析。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • 解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題

    解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題

    這篇文章主要介紹了解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 基于Vue CSR的微前端實現(xiàn)方案實踐

    基于Vue CSR的微前端實現(xiàn)方案實踐

    這篇文章主要介紹了基于Vue CSR的微前端實現(xiàn)方案實踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 在Vue中實現(xiàn)添加全局store

    在Vue中實現(xiàn)添加全局store

    這篇文章主要介紹了在Vue中實現(xiàn)添加全局store方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue3.0自定義指令(drectives)知識點總結(jié)

    vue3.0自定義指令(drectives)知識點總結(jié)

    在本篇文章里小編給大家整體了一篇關(guān)于vue3.0自定義指令(drectives)知識點總結(jié),有興趣的朋友們可以學(xué)習(xí)下。
    2020-12-12
  • 如何在vue里添加好看的lottie動畫

    如何在vue里添加好看的lottie動畫

    這篇文章主要介紹了在vue里添加好看的lottie動畫效果的方法,在vue中引入lottie非常簡單,需要的朋友可以參考下
    2018-08-08
  • vite環(huán)境變量.env文件的配置及使用

    vite環(huán)境變量.env文件的配置及使用

    在Vite中,我們可以使用環(huán)境變量來管理不同環(huán)境下的配置,本文主要介紹了vite環(huán)境變量.env文件的配置及使用,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • vue 動態(tài)表單開發(fā)方法案例詳解

    vue 動態(tài)表單開發(fā)方法案例詳解

    這篇文章主要介紹了vue 動態(tài)表單開發(fā)方法,結(jié)合具體案例形式詳細(xì)分析了vue.js動態(tài)表單相關(guān)原理、開發(fā)步驟與實現(xiàn)技巧,需要的朋友可以參考下
    2019-12-12

最新評論