成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

《深入理解ES6》筆記——代理(Proxy)和反射(Reflection)API(12)

ZHAO_ / 1053人閱讀

摘要:方法與代理處理程序的方法相同。使用給目標函數(shù)傳入指定的參數(shù)。當然,不用反射也可以讀取的值。的例子我們可以理解成是攔截了方法,然后傳入?yún)?shù),將返回值賦值給,這樣我們就能在需要讀取這個返回值的時候調(diào)用。這種代理模式和的代理有異曲同工之妙。

反射 Reflect

當你見到一個新的API,不明白的時候,就在瀏覽器打印出來看看它的樣子。

反射的概念

Reflect 是一個內(nèi)置的對象,它提供可攔截JavaScript操作的方法。方法與代理處理程序的方法相同。Reflect 不是一個函數(shù)對象,因此它是不可構(gòu)造的。

    new Reflect() //錯誤的寫法
反射的使用

Reflect提供了一些靜態(tài)方法,靜態(tài)方法是指只能通過對象自身訪問的的方法,這個知識在前面幾章講解過。所有方法的詳細解析,前往 Reflect詳解 查看。

靜態(tài)方法列表:這么多靜態(tài)方法,你需要學(xué)會的是如何使用它們。

1、Reflect.apply()
2、Reflect.construct()
3、Reflect.defineProperty()
4、Reflect.deleteProperty()
5、Reflect.enumerate()
6、Reflect.get()
7、Reflect.getOwnPropertyDescriptor()
8、Reflect.getPrototypeOf()
9、Reflect.has()
10、Reflect.isExtensible()
11、Reflect.ownKeys()
12、Reflect.preventExtensions()
13、Reflect.set()
14、Reflect.setPrototypeOf()

靜態(tài)方法的使用:

demo1:使用Reflect.get()獲取目標對象指定key的value。

let obj = {
    a: 1
};

let s1 = Reflect.get(obj, "a")
console.log(s1) // 1

demo2:使用Reflect.apply給目標函數(shù)floor傳入指定的參數(shù)。

const s2 = Reflect.apply(Math.floor, undefined, [1.75]); 
console.log(s2) // 1
進一步理解Reflect

看了上面的例子和方法,我們知道Reflect可以攔截JavaScript代碼,包括攔截對象,攔截函數(shù)等,然后對攔截到的對象或者函數(shù)進行讀寫等操作。

比如demo1的get()方法,攔截obj對象,然后讀取key為a的值。當然,不用反射也可以讀取a的值。

再看demo2的apply()方法,這個方法你應(yīng)該比較了解了,和數(shù)組中使用apply不同的是,Reflect.apply()提供了3個參數(shù),第一個參數(shù)是反射的函數(shù),后面2個參數(shù)才是和數(shù)組的apply一致。demo2的例子我們可以理解成是攔截了Math.floor方法,然后傳入?yún)?shù),將返回值賦值給s2,這樣我們就能在需要讀取這個返回值的時候調(diào)用s2。

//數(shù)組使用apply
const arr = [1, 2, 3]
function a() {
  return Array.concat.apply(null, arguments)
}
const s = a(arr)
console.log(s) // [1, 2 ,3]

其實Reflect的作用和我們下面要講的Proxy是差不多的。

代理 Proxy

Proxy這個詞相信你已經(jīng)聽過無數(shù)遍了,我曾經(jīng)寫過一篇webpack使用代理來攔截指定域的API請求,轉(zhuǎn)發(fā)到新的目標URL的文章 webpack中使用proxy。但是注意Proxy和proxy,大小寫字母之間是不同的。本章講的是大寫字母開頭的Proxy。

語法
let p = new Proxy(target, handler);

target:一個目標對象(可以是任何類型的對象,包括本機數(shù)組,函數(shù),甚至另一個代理)用Proxy來包裝。
handler:一個對象,其屬性是當執(zhí)行一個操作時定義代理的行為的函數(shù)。

代理的使用

基礎(chǔ)demo:Proxy的demo有很多,我們只分析基礎(chǔ)demo,主要看new Proxy({}, handler)的操作,指定目標obj對象,然后handler對象執(zhí)行g(shù)et()操作,get()返回值的判斷是,如果name是target目標對象的屬性,則返回target[name]的值,否則返回37,最后測試的時候,p.a是對象p的key,所以返回a的value,而p.b不存在,返回37。

const obj = {
  a: 10
}
let handler = {
    get: function(target, name){
        console.log("test: ", target, name)
        // test:  {"a":10} a
        // test:  {"a":10} b
        return name in target ? target[name] : 37
    }
}
let p = new Proxy(obj, handler)
console.log(p.a, p.b) // 10 37

這個例子的作用是攔截目標對象obj,當執(zhí)行obj的讀寫操作時,進入handler函數(shù)進行判斷,如果讀取的key不存在,則返回默認值。

我們使用一些http-proxy插件或者webpack的時候,有時候需要訪問某個api時,跳轉(zhuǎn)到指定的url,這種方式也能解決跨域訪問。這種代理模式和Proxy的代理有異曲同工之妙。但是,別混為一體了。

module.exports = {
    devServer: {
       proxy: [
           {
                context: "/api/*", //代理API
                target: "https://www.hyy.com", //目標URL
                secure: false
          }
       ]
    }
}
總結(jié)

無論是反射還是代理,除了他們使用方法不同之外,他們所作的事情非常相似,都可以理解成攔截某個東西,然后執(zhí)行某個函數(shù)操作,再返回函數(shù)操作的結(jié)果。

大部分前端在日常業(yè)務(wù)需求中,幾乎很少使用到這2個API,實際使用場景還得在以后的開發(fā)中慢慢挖掘。

=> 返回文章目錄

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88341.html

相關(guān)文章

  • 深入理解ES6筆記——代理Proxy反射ReflectionAPI12

    摘要:方法與代理處理程序的方法相同。使用給目標函數(shù)傳入指定的參數(shù)。當然,不用反射也可以讀取的值。的例子我們可以理解成是攔截了方法,然后傳入?yún)?shù),將返回值賦值給,這樣我們就能在需要讀取這個返回值的時候調(diào)用。這種代理模式和的代理有異曲同工之妙。 反射 Reflect 當你見到一個新的API,不明白的時候,就在瀏覽器打印出來看看它的樣子。 showImg(https://segmentfault....

    shiina 評論0 收藏0
  • 深入理解ES6筆記(十一)代理Proxy反射ReflectionAPI12

    摘要:是陷阱函數(shù)對應(yīng)的反射方法,同時也是操作的默認行為。對象外形指的是對象已有的屬性與方法的集合,由于該屬性驗證只須在讀取屬性時被觸發(fā),因此只要使用陷阱函數(shù)。無論該屬性是對象自身的屬性還是其原型的屬性。 主要知識點:代理和反射的定義、常用的陷阱函數(shù)、可被撤銷的代理、將代理對象作為原型使用、將代理作為類的原型showImg(https://segmentfault.com/img/bVbfWr...

    explorer_ddf 評論0 收藏0
  • ES6中的代理Proxy反射Reflection

    摘要:代理和反射的定義調(diào)用可常見代替其它目標對象的代理,它虛擬化了目標,所以二者看起來功能一致。代理可攔截引擎內(nèi)部目標的底層對象操作,這些底層操作被攔截后會觸發(fā)響應(yīng)特定操作的陷阱函數(shù)。 代理和反射的定義 調(diào)用 new Proxy() 可常見代替其它目標 (target) 對象的代理,它虛擬化了目標,所以二者看起來功能一致。 代理可攔截JS引擎內(nèi)部目標的底層對象操作,這些底層操作被攔截后會觸發(fā)...

    Markxu 評論0 收藏0
  • 深入理解ES6筆記——導(dǎo)讀

    摘要:最近買了深入理解的書籍來看,為什么學(xué)習(xí)這么久還要買這本書呢主要是看到核心團隊成員及的創(chuàng)造者為本書做了序,作為一個粉絲,還是挺看好這本書能給我?guī)硪粋€新的升華,而且本書的作者也非常厲害。 使用ES6開發(fā)已經(jīng)有1年多了,以前看的是阮一峰老師的ES6教程,也看過MDN文檔的ES6語法介紹。 最近買了《深入理解ES6》的書籍來看,為什么學(xué)習(xí)ES6這么久還要買這本書呢?主要是看到Daniel A...

    Godtoy 評論0 收藏0

發(fā)表評論

0條評論

ZHAO_

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<