數(shù)據(jù)攔截

Object.defineProterty

數(shù)據(jù)屬性:value, writable, configurable, enumerable

訪問(wèn)器屬性:get,set

注:不能同時(shí)設(shè)置value和writable,這兩對(duì)屬性是互斥的

let objOne={}, defaultNameOne="這是默認(rèn)值2";

Object.defineProperty(obj, 'name',? {

????get() {

????????return????defaultNameOne;?

?????},

????set(value) { defaultNameOne =value; }?

?});?

?console.log(objOne.name);?

?objOne.name = "這是改變值2";?

?console.log(objOne.name);

proxy

let handler = {

? ? get(target, key, receiver) {

? ? ? console.log("get", key);

? ? ? return Reflect.get(target, key, receiver);

? ? },

? ? set(target, key, value, receiver) {

? ? ? console.log("set", key, value);

? ? ? return Reflect.set(target, key, value, receiver);

? ? }

? };

? let proxy = new Proxy(obj, handler);

? proxy.name = "李四";

? proxy.age = 24;

defineProterty和proxy的對(duì)比:

1.defineProterty是es5的標(biāo)準(zhǔn),proxy是es6的標(biāo)準(zhǔn);

2.proxy可以監(jiān)聽(tīng)到數(shù)組索引賦值,改變數(shù)組長(zhǎng)度的變化;

3.proxy是監(jiān)聽(tīng)對(duì)象,不用深層遍歷,defineProterty是監(jiān)聽(tīng)屬性;

3.利用defineProterty實(shí)現(xiàn)雙向數(shù)據(jù)綁定(vue2.x采用的核心)

4.利用proxy實(shí)現(xiàn)雙向數(shù)據(jù)綁定(vue3.x會(huì)采用)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容