vue3響應式數(shù)據(jù)

一 基于proxy的Observer

1 什么是proxy
Proxy 對象用于定義基本操作的自定義行為(如屬性查找剪勿、賦值脚翘、枚舉、函數(shù)調(diào)用等)兑牡。
proxy是es6新特性,為了對目標的作用主要是通過handler對象中的攔截方法攔截目標對象target的某些行為(如屬性查找税灌、賦值均函、枚舉、函數(shù)調(diào)用等)菱涤。
/* target: 目標對象苞也,待要使用 Proxy 包裝的目標對象(可以是任何類型的對象,包括原生數(shù)組粘秆,函數(shù)如迟,甚至另一個代理)。 /
/
handler: 一個通常以函數(shù)作為屬性的對象攻走,各屬性中的函數(shù)分別定義了在執(zhí)行各種操作時代理 proxy 的行為殷勘。 */
const proxy = new Proxy(target, handler);
2 為什么要用proxy,改用proxy之后的利與弊
** 3.0 將帶來一個基于 Proxy 的 observer 實現(xiàn)昔搂,它可以提供覆蓋語言 (JavaScript——譯注) 全范圍的響應式能力玲销,消除了當前 Vue 2 系列中基于 Object.defineProperty 所存在的一些局限,這些局限包括:1 對屬性的添加巩趁、刪除動作的監(jiān)測痒玩; 2 對數(shù)組基于下標的修改淳附、對于 .length 修改的監(jiān)測议慰; 3 對 Map、Set奴曙、WeakMap 和 WeakSet 的支持别凹;;

vue2.0 用 Object.defineProperty 作為響應式原理的實現(xiàn)洽糟,但是會有它的局限性炉菲,比如 無法監(jiān)聽數(shù)組基于下標的修改堕战,不支持 Map、Set拍霜、WeakMap 和 WeakSet等缺陷 嘱丢,所以改用了proxy解決了這些問題,這也意味著vue3.0將放棄對低版本瀏覽器的兼容(兼容版本ie11以上)祠饺。
3 proxy中hander對象的基本用法
vue3.0 響應式用到的捕獲器(接下來會重點介紹)
handler.has() -> in 操作符 的捕捉器越驻。 (vue3.0 用到)
handler.get() -> 屬性讀取 操作的捕捉器。 (vue3.0 用到)
handler.set() -> 屬性設置* 操作的捕捉器道偷。 (vue3.0 用到)
handler.deleteProperty() -> delete 操作符 的捕捉器缀旁。(vue3.0 用到)
handler.ownKeys() -> Object.getOwnPropertyNames 方法和 Object.getOwnPropertySymbols 方法的捕捉器。(vue3.0 用到)

vue3.0 響應式?jīng)]用到的捕獲器(有興趣的同學可以研究一下)

handler.getPrototypeOf() -> Object.getPrototypeOf 方法的捕捉器勺鸦。
handler.setPrototypeOf() -> Object.setPrototypeOf 方法的捕捉器并巍。
handler.isExtensible() -> Object.isExtensible 方法的捕捉器。
handler.preventExtensions() -> Object.preventExtensions 方法的捕捉器换途。
handler.getOwnPropertyDescriptor() -> Object.getOwnPropertyDescriptor 方法的捕捉器懊渡。
handler.defineProperty() -> Object.defineProperty 方法的捕捉器。
handler.apply() -> 函數(shù)調(diào)用操作 的捕捉器军拟。
handler.construct() -> new 操作符 的捕捉器距贷。
① has捕獲器
has(target, propKey)
target:目標對象
propKey:待攔截屬性名
作用: 攔截判斷target對象是否含有屬性propKey的操作
攔截操作: propKey in proxy; 不包含for…in循環(huán)
對應Reflect: Reflect.has(target, propKey)

                                    const he=new Proxy(data,{
                //查詢數(shù)據(jù)  
                get(target,propName){
                    console.log("讀取p的${propName}屬性")
                    return target[propName]
                },
                //新增和修改數(shù)據(jù)
                set(target,propName,value){
                    console.log("讀取p的${propName}屬性")
                    target[propName]=value
                },
                deleteProperty(target,propName){
                    console.log("讀取p的${propName}屬性")
                    return delete target[propName]
                }
                
            }   )

② get捕獲器
get(target, propKey, receiver)

target:目標對象

propKey:待攔截屬性名

receiver: proxy實例

返回: 返回讀取的屬性

作用:攔截對象屬性的讀取

攔截操作:proxy[propKey]或者點運算符

對應Reflect: Reflect.get(target, propertyKey[, receiver])
③ set捕獲器
set(target,propKey, value,receiver)

target:目標對象

propKey:待攔截屬性名

value:新設置的屬性值

receiver: proxy實例

返回:嚴格模式下返回true操作成功;否則失敗吻谋,報錯

作用: 攔截對象的屬性賦值操作

攔截操作: proxy[propkey] = value

對應Reflect: Reflect.set(obj, prop, value, receiver)
④ deleteProperty 捕獲器
deleteProperty(target, propKey)

target:目標對象

propKey:待攔截屬性名

返回:嚴格模式下只有返回true, 否則報錯

作用: 攔截刪除target對象的propKey屬性的操作

攔截操作: delete proxy[propKey]

對應Reflect: Reflect.delete(obj, prop)
(183條消息) vue3.0 響應式原理(超詳細)_zl_Alien的博客-CSDN博客_vue3.0響應式原理

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末忠蝗,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子漓拾,更是在濱河造成了極大的恐慌阁最,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件骇两,死亡現(xiàn)場離奇詭異速种,居然都是意外死亡,警方通過查閱死者的電腦和手機低千,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門配阵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人示血,你說我怎么就攤上這事棋傍。” “怎么了难审?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵瘫拣,是天一觀的道長。 經(jīng)常有香客問我告喊,道長麸拄,這世上最難降的妖魔是什么派昧? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮拢切,結果婚禮上蒂萎,老公的妹妹穿的比我還像新娘。我一直安慰自己淮椰,他們只是感情好岖是,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著实苞,像睡著了一般豺撑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上黔牵,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天聪轿,我揣著相機與錄音,去河邊找鬼猾浦。 笑死陆错,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的金赦。 我是一名探鬼主播音瓷,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼夹抗!你這毒婦竟也來了绳慎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤漠烧,失蹤者是張志新(化名)和其女友劉穎杏愤,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體已脓,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡珊楼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了度液。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片厕宗。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖堕担,靈堂內(nèi)的尸體忽然破棺而出已慢,到底是詐尸還是另有隱情,我是刑警寧澤照宝,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布蛇受,位于F島的核電站句葵,受9級特大地震影響厕鹃,放射性物質(zhì)發(fā)生泄漏兢仰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一剂碴、第九天 我趴在偏房一處隱蔽的房頂上張望把将。 院中可真熱鬧,春花似錦忆矛、人聲如沸察蹲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽洽议。三九已至,卻和暖如春漫拭,著一層夾襖步出監(jiān)牢的瞬間亚兄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工采驻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留审胚,地道東北人。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓礼旅,卻偏偏與公主長得像膳叨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子痘系,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容