ES6 反射和代理

反射和代理

一瓦哎、反射

1唉韭、反射是什么

Reflect是一個(gè)內(nèi)置的JS對(duì)象茸习,它提供了一系列方法畜隶,可以讓開發(fā)者通過調(diào)用這些方法,訪問一些JS底層功能
由于它類似于其他語言的反射号胚,因此取名為Reflect

2籽慢、可以做什么

使用Reflect可以實(shí)現(xiàn)諸如 屬性的賦值與取值、調(diào)用普通函數(shù)猫胁、調(diào)用構(gòu)造函數(shù)箱亿、判斷屬性是否存在與對(duì)象中等等功能

3、API

方法 簡介
Reflect.set(target,protertyKey,value) 給對(duì)象賦值
Reflect.get(target,protertyKey) 獲取對(duì)象的值
Reflect.apply(target,this,arguments) 調(diào)用函數(shù)
Reflect.defineProperty(target,protertyKey) 屬性描述
Reflect.deleteProperty(target,protertyKey) 刪除對(duì)象的屬性
Reflect.construct(target,arguments) 使用構(gòu)造函數(shù)的方式創(chuàng)建對(duì)象
Reflect.has(target,protertyKey) 判斷一個(gè)對(duì)象是否擁有一個(gè)屬性
// 1.Reflect.set(target,protertyKey,value);設(shè)置對(duì)象target的屬性propertyKey的值為value弃秆,等同于給對(duì)象的屬性賦值
const obj1 = {
     a: 1,
     b: 2
}
//以前的賦值届惋,但是有了=號(hào)
obj.c = 3;
//反射中的賦值
Reflect.set(obj, "c", 10)
console.log(obj)

// 2.Reflect.get(target,protertyKey);讀取對(duì)象target的屬性propertyKey髓帽,等同于讀取對(duì)象的屬性值 
console.log(Reflect.get(obj, "a"));

// 3.Reflect.apply(target,this,arguments)調(diào)用一個(gè)指定的函數(shù),并綁定this和參數(shù)列表脑豹。等同于函數(shù)調(diào)用
function fun(a, b) {
    return a + b;
}
// fun(3,4)
Reflect.apply(fun, null, [3, 4])

// 4.Reflect.defineProperty(target,protertyKey)定義屬性類似于Object.defineProperty郑藏,不同的是如果配置出現(xiàn)問題,返回false而不是報(bào)錯(cuò)
Reflect.defineProperty(obj, 'a', {
    value: 10,
    configurable: false,
    enumerable: false,
    writable: false
})

// 5.Reflect.deleteProperty(target,protertyKey)刪除屬性
//delete obj.a;
Reflect.deleteProperty(obj, "a")
console.log(obj)

// 6.Reflect.construct(target,arguments)  //使用構(gòu)造函數(shù)的方式創(chuàng)建對(duì)象
// new 不讓用創(chuàng)建
function Test(a, b) {
     this.a = a;
     this.b = b;

// const t = new Test(5,6)
const t = Reflect.construct(Test, [5, 6])
console.log(t)

// 7.Reflect.has(target,protertyKey)   判斷一個(gè)對(duì)象是否擁有某個(gè)屬性
console.log('a' in obj)
console.log(Reflect.has(obj, "a"));

二瘩欺、代理

1必盖、概念

代理就是一個(gè)對(duì)象的所有方法和屬性的調(diào)用都需要借助另一個(gè)對(duì)象

2、作用

提供了修改底層實(shí)現(xiàn)的方式

3俱饿、創(chuàng)建

const p = new Proxy(target,handler)
//target 目標(biāo)對(duì)象
//handler 是一個(gè)普通對(duì)象歌粥,可以重寫底層方法
//返回一個(gè)代理對(duì)象
//p為代理對(duì)象
const obj = {
    a: 1,
    b: 2 
}
const proxy = new Proxy(obj, { //這個(gè)就是代理對(duì)象
}
console.log(proxy);
proxy.abc = 10;
console.log(proxy);
console.log(obj);//obj中也有了abc這個(gè)屬性

const proxy = new Proxy(obj, { //這個(gè)就是代理對(duì)象
    set(target, protertyKey, value) {
        console.log(`設(shè)置了${protertyKey}屬性,值為${value}`);
        Reflect.set(target, protertyKey, value);
    },
    get(target, protertyKey) {
        console.log(`訪問了${protertyKey}屬性`);
        return Reflect.get(target, protertyKey)
    },
    has(target, protertyKey) {
        return Reflect.has(target,protertyKey)
        return false;
    },
    // nan(target, protertyKey) { //不管這的名字是什么拍埠,都會(huì)走進(jìn)函數(shù)中
    //     Reflect.deleteProperty(target, protertyKey)
    // },
    delete(target, protertyKey) {
         Reflect.deleteProperty(target, protertyKey)
    }
})
console.log(proxy);
proxy.a = 10;
console.log('a' in proxy);

觀察者模式

  • ES5寫觀察者模式:
<div id="container">
</div>
    // 觀察者模式
    // 有一個(gè)對(duì)象失驶,是一個(gè)觀察者,觀察屬性值的變化械拍,當(dāng)屬性值發(fā)生變化的時(shí)候突勇,去做一些事情
    function observer(target) {
        const div = document.getElementById("container");
        const ob = {}; //創(chuàng)建一個(gè)新的對(duì)象,這個(gè)新的對(duì)象就是代理對(duì)象坷虑,最后會(huì)在函數(shù)執(zhí)行完以后被返回
        const props = Object.keys(target);
        for (const prop of props) {
            // ob[prop] = target[prop];
            Object.defineProperty(ob, prop, {
                get() {
                    return target[prop];
                },
                set(val) {
                    target[prop] = val;
                    render()
                },
                enumerable: true //通過存儲(chǔ)器的屬性全都會(huì)變成false
            })
        }
        render()
        function render() { //渲染函數(shù)
            let html = "";
            for (const prop of Object.keys(ob)) {
                html += `
                    <p>
                        <span>${prop}:</span>
                        <span>${ob[prop]}</span>
                    </p>
                `
            }
            div.innerHTML = html;
        }
        return ob;
    }
    const target = {
        a: 1,
        b: 2
    }
    const obj = observer(target);
    target.a = 1000;  //目標(biāo)函數(shù)不改變甲馋,讓代理函數(shù)obj干
    obj.a = 5000;
    obj.c = 8; //沒有配置obj.c
  • ES6寫觀察者模式:
function observer(target) {
        const div = document.getElementById("container");
        const proxy = new Proxy(target, {
            set(target, prop, value) {
                Reflect.set(target, prop, value)
                render()
            },
            get(target, prop) {
                return Reflect.get(target, prop)
            }
        })
        render()
        function render() {
            let html = "";
            for (const prop of Object.keys(target)) {
                html += `
                    <p>
                        <span>${prop}:</span>
                        <span>${target[prop]}</span>
                    </p>
                `
            }
            div.innerHTML = html;
        }
        return proxy;
    }
    const target = {
        a: 1,
        b: 2
    }
    const obj = observer(target);
    target.a = 1000;  //目標(biāo)函數(shù)不改變,讓代理函數(shù)obj干
    obj.a = 5000;
    obj.c = 8; //代理配置可以改變屬性
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末迄损,一起剝皮案震驚了整個(gè)濱河市定躏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌芹敌,老刑警劉巖痊远,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異氏捞,居然都是意外死亡碧聪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門液茎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來逞姿,“玉大人,你說我怎么就攤上這事捆等≈驮欤” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵栋烤,是天一觀的道長谒养。 經(jīng)常有香客問我,道長明郭,這世上最難降的妖魔是什么买窟? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任丰泊,我火速辦了婚禮,結(jié)果婚禮上蔑祟,老公的妹妹穿的比我還像新娘趁耗。我一直安慰自己,他們只是感情好疆虚,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著满葛,像睡著了一般径簿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上嘀韧,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天篇亭,我揣著相機(jī)與錄音,去河邊找鬼锄贷。 笑死译蒂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谊却。 我是一名探鬼主播柔昼,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼炎辨!你這毒婦竟也來了捕透?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤碴萧,失蹤者是張志新(化名)和其女友劉穎乙嘀,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體破喻,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡虎谢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了曹质。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片婴噩。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖咆繁,靈堂內(nèi)的尸體忽然破棺而出讳推,到底是詐尸還是另有隱情,我是刑警寧澤玩般,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布银觅,位于F島的核電站,受9級(jí)特大地震影響坏为,放射性物質(zhì)發(fā)生泄漏究驴。R本人自食惡果不足惜镊绪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望洒忧。 院中可真熱鬧蝴韭,春花似錦、人聲如沸熙侍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛉抓。三九已至庆尘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間巷送,已是汗流浹背驶忌。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留笑跛,地道東北人付魔。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像飞蹂,于是被迫代替她去往敵國和親几苍。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

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

  • 屬性描述符 Property Descriptor 屬性描述符晤柄,用于描述一個(gè)屬性的相關(guān)信息擦剑。 通過Object.g...
    欣欣l閱讀 267評(píng)論 1 0
  • 原本想稍微整理一下 ES 新特性,沒想到花了相當(dāng)多的時(shí)間芥颈,本文也巨長惠勒,依然推薦使用 簡悅[https://gith...
    401閱讀 1,863評(píng)論 0 5
  • 前面的話 ??ES5和ES6致力于為開發(fā)者提供JS已有卻不可調(diào)用的功能。例如在ES5出現(xiàn)以前爬坑,JS環(huán)境中的對(duì)象包含...
    CodeMT閱讀 1,419評(píng)論 0 2
  • 前言: vue 3.o據(jù)說已經(jīng)將Object.defineProperty換成了proxy為什么要換呢纠屋?優(yōu)勢(shì)如下:...
    安石0閱讀 1,062評(píng)論 1 0
  • 第一章:塊級(jí)作用域綁定 塊級(jí)聲明 1.var聲明及變量提升機(jī)制:在函數(shù)作用域或者全局作用域中通過關(guān)鍵字var聲明的...
    BeADre_wang閱讀 825評(píng)論 0 0