• <b id="gimrh"><noscript id="gimrh"></noscript></b>
    1. <video id="gimrh"><menu id="gimrh"></menu></video>
      <tt id="gimrh"><tbody id="gimrh"></tbody></tt>

      400-650-7353
      您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】js的捕捉器---Proxy代理對象

      【Web前端基礎知識】js的捕捉器---Proxy代理對象

      • 發布: Web前端培訓
      • 來源:優就業
      • 2021-09-28 14:03:03
      • 閱讀()
      • 分享
      • 手機端入口

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

      簡單的舉個例子:

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

      那我們為什么會需要代理呢?這個代理就像是我們生活中的每一次次的消費之后的記賬,舉個例子來說吧。

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

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

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

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

      因為我們對目標對象的屬性操作改為了對代理對象相同的屬性操作,所以就需要我們在最后通過Reflact執行目標對象的原始操作。

      1. var con = 0 
      2. // 目標對象 
      3. var our = {wallet: 200} 
      4. // 捕獲器trap 
      5. var handlers = { 
      6.     set(target, key, val) { 
      7.         // target 目標對象 
      8.         // key 代理對象要修改的屬性 
      9.          
      10.         // 記錄一筆消費 
      11.         con++ 
      12.         // 通過Reflact對象觸發原始目標對象的屬性操作 
      13.         // 相當于執行 target[key] = val 
      14.         Reflect.set(target, key, val) 
      15.     } 
      16. // 代理對象 
      17. var p = new Proxy(our, handlers) 
      18. // 將對目標對象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 

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

      假如某一天,我們實現了財務自由,不需要再精打細算的記錄每一筆消費時,就可能需要取消之前的代理了,那我們應該如何操作呢,接下來告訴你,代碼如下:

      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創建代理 
      10. var t = Proxy.revocable(our, handlers) 
      11. var p = t.proxy 
      12. var prevoke = t.revoke 
      13.  
      14. // 使用代理對象進行消費記賬 
      15. p.wallet = 197 
      16. p.wallet = 194 
      17. p.wallet = 191 
      18.  
      19. // 某一天,我們實現了一個小目標 
      20. p.wallet = 100000000 
      21. // 我們不再需要記賬,取消之前創建的代理 
      22. prevoke() // 執行prevoke即可 
      23.  
      24. p.wallet = 99999997 // 會顯示報錯 (代理取消就不能再使用) 

       

      文章“【Web前端基礎知識】js的捕捉器---Proxy代理對象”已幫助

      更多內容

      >>本文地址:http://www.threeriversmusicproducts.com/zhuanye/2021/70196.html

      THE END  

      聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

      領取零基礎自學IT資源

      (內含學習路線+視頻教程+項目源碼)

      涉及Java、Web前端、UI設計、軟件測試、Python等多個IT熱門方向

      打開微信掃一掃即可領取哦~

      1 您的年齡

      2 您的學歷

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

      獲取測試結果
      • 大前端大前端
      • 大數據大數據
      • 互聯網營銷互聯網營銷
      • JavaJava
      • Linux云計算Linux
      • Python+人工智能Python
      • 嵌入式物聯網嵌入式
      • 全域電商運營全域電商運營
      • 軟件測試軟件測試
      • 室內設計室內設計
      • 平面設計平面設計
      • 電商設計電商設計
      • 網頁設計網頁設計
      • 全鏈路UI/UE設計UI設計
      • VR/AR游戲開發VR/AR
      • 網絡安全網絡安全
      • 新媒體與短視頻運營新媒體
      • 直播帶貨直播帶貨
      • 智能機器人軟件開發智能機器人
       

      快速通道fast track

      近期開班時間TIME

      bl乱J伦高HH

    2. <b id="gimrh"><noscript id="gimrh"></noscript></b>
      1. <video id="gimrh"><menu id="gimrh"></menu></video>
        <tt id="gimrh"><tbody id="gimrh"></tbody></tt>