400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎(chǔ)知識】js的捕捉器---Proxy代理對象

【W(wǎng)eb前端基礎(chǔ)知識】js的捕捉器---Proxy代理對象

  • 發(fā)布: Web前端培訓(xùn)
  • 來源:優(yōu)就業(yè)
  • 2021-09-28 14:03:03
  • 閱讀()
  • 分享
  • 手機(jī)端入口

在談到j(luò)s的是trap的時候,我們首先要了解一下什么是Proxy代理?Proxy對象用于創(chuàng)建一個對象的代理,從而實(shí)現(xiàn)基本操作的攔截和自定義(如屬性查找、賦值、枚舉、函數(shù)調(diào)用等)。[來源于MDN的說明]。

簡單的舉個例子:

  1. var p = new Proxy(our, handlers); 
  2.    //p就是通過new Proxy創(chuàng)建的代理對象 

那我們?yōu)槭裁磿枰砟?這個代理就像是我們生活中的每一次次的消費(fèi)之后的記賬,舉個例子來說吧。

  1. // our代表我們,wallet屬性指我們錢包,現(xiàn)在我們錢包里有200元 
  2. // con指我們的消費(fèi)次數(shù),每次消費(fèi)次數(shù)都會加1, 記一筆賬 
  3. var our = {wallet: 200} 
  4. var con = 0 
  5.  
  6. // 這個月,我們喝了四次透心涼心飛揚(yáng),每次的消費(fèi)我們都會記上一筆 
  7.  
  8. // 今天消費(fèi)3元 
  9. con++ 
  10. our.wallet =197 
  11.  
  12. // 今天消費(fèi)3元 
  13. con++ 
  14. our.wallet = 194 
  15.  
  16. // 今天消費(fèi)3元 
  17. con++ 
  18. our.wallet = 191 
  19.  
  20. // 今天消費(fèi)3元 
  21. con++ 
  22. our.wallet = 188 
  23.  
  24. // 今天消費(fèi)3元 
  25. con++ 

每次我們在修改錢包剩余金額時,都要執(zhí)行一次con++去執(zhí)行一次記賬的操作,那么有沒有更簡單的方式,可以讓我們不需要每次都寫上一行代碼來增加消費(fèi)的次數(shù)呢?

答案當(dāng)然是有的,它就是Proxy代理對象。我們可以通過使用代理對象,假設(shè)你想對目標(biāo)對象的屬性操作全部改為對代理對象相同屬性的操作,那么在代理對象中,它提供了對屬性獲取 [[get]] 和修改 [[set]] 等操作的攔截,js中將這種的攔截稱為捕捉器。

通過這種的捕捉器,我們就可以捕獲到代碼中對屬性的操作時機(jī),讓我們能夠先執(zhí)行我們自定義的業(yè)務(wù)邏輯代碼。

因?yàn)槲覀儗δ繕?biāo)對象的屬性操作改為了對代理對象相同的屬性操作,所以就需要我們在最后通過Reflact執(zhí)行目標(biāo)對象的原始操作。

  1. var con = 0 
  2. // 目標(biāo)對象 
  3. var our = {wallet: 200} 
  4. // 捕獲器trap 
  5. var handlers = { 
  6.     set(target, key, val) { 
  7.         // target 目標(biāo)對象 
  8.         // key 代理對象要修改的屬性 
  9.          
  10.         // 記錄一筆消費(fèi) 
  11.         con++ 
  12.         // 通過Reflact對象觸發(fā)原始目標(biāo)對象的屬性操作 
  13.         // 相當(dāng)于執(zhí)行 target[key] = val 
  14.         Reflect.set(target, key, val) 
  15.     } 
  16. // 代理對象 
  17. var p = new Proxy(our, handlers) 
  18. // 將對目標(biāo)對象our的屬性wallet操作改為代理對象相同屬性wallet的操作 
  19. p.wallet = 197 
  20. p.wallet = 194 
  21. p.wallet = 191 
  22. p.wallet = 188 
  23. p.wallet = 185 
  24.  
  25. console.log(our.wallet) // 185 
  26. console.log(consume) // 5 

那我們不禁開始思考一個問題:如何取消代理呢?

假如某一天,我們實(shí)現(xiàn)了財務(wù)自由,不需要再精打細(xì)算的記錄每一筆消費(fèi)時,就可能需要取消之前的代理了,那我們應(yīng)該如何操作呢,接下來告訴你,代碼如下:

  1. var con = 0 
  2. var our = {wallet:  200} 
  3. var handlers = { 
  4.     set(target, key, val) { 
  5.         con++ 
  6.         Reflect.set(target, key, val) 
  7.     } 
  8.  
  9. // 使用Proxy.revocable創(chuàng)建代理 
  10. var t = Proxy.revocable(our, handlers) 
  11. var p = t.proxy 
  12. var prevoke = t.revoke 
  13.  
  14. // 使用代理對象進(jìn)行消費(fèi)記賬 
  15. p.wallet = 197 
  16. p.wallet = 194 
  17. p.wallet = 191 
  18.  
  19. // 某一天,我們實(shí)現(xiàn)了一個小目標(biāo) 
  20. p.wallet = 100000000 
  21. // 我們不再需要記賬,取消之前創(chuàng)建的代理 
  22. prevoke() // 執(zhí)行prevoke即可 
  23.  
  24. p.wallet = 99999997 // 會顯示報錯 (代理取消就不能再使用) 

 

文章“【W(wǎng)eb前端基礎(chǔ)知識】js的捕捉器---Proxy代理對象”已幫助

更多內(nèi)容

>>本文地址:http://liujunjsxg.cn/zhuanye/2021/70196.html

THE END  

聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

1 您的年齡

2 您的學(xué)歷

3 您更想做哪個方向的工作?

獲取測試結(jié)果
  • 大前端大前端
  • 大數(shù)據(jù)大數(shù)據(jù)
  • 互聯(lián)網(wǎng)營銷互聯(lián)網(wǎng)營銷
  • JavaJava
  • Linux云計(jì)算Linux
  • Python+人工智能Python
  • 嵌入式物聯(lián)網(wǎng)嵌入式
  • 全域電商運(yùn)營全域電商運(yùn)營
  • 軟件測試軟件測試
  • 室內(nèi)設(shè)計(jì)室內(nèi)設(shè)計(jì)
  • 平面設(shè)計(jì)平面設(shè)計(jì)
  • 電商設(shè)計(jì)電商設(shè)計(jì)
  • 網(wǎng)頁設(shè)計(jì)網(wǎng)頁設(shè)計(jì)
  • 全鏈路UI/UE設(shè)計(jì)UI設(shè)計(jì)
  • VR/AR游戲開發(fā)VR/AR
  • 網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全
  • 新媒體與短視頻運(yùn)營新媒體
  • 直播帶貨直播帶貨
  • 智能機(jī)器人軟件開發(fā)智能機(jī)器人
 

快速通道fast track

近期開班時間TIME