<ins id="6k1m6"><video id="6k1m6"></video></ins>

    <ruby id="6k1m6"><option id="6k1m6"></option></ruby>
    <code id="6k1m6"><option id="6k1m6"></option></code>
  1. <output id="6k1m6"></output>
    400-650-7353
    您所在的位置:首頁(yè) > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎知識】js的捕捉器---Proxy代理對象

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

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

    簡(jiǎn)單的舉個(gè)例子:

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

    那我們?yōu)槭裁磿?huì )需要代理呢?這個(gè)代理就像是我們生活中的每一次次的消費之后的記賬,舉個(gè)例子來(lái)說(shuō)吧。

    1. // our代表我們,wallet屬性指我們錢(qián)包,現在我們錢(qián)包里有200元 
    2. // con指我們的消費次數,每次消費次數都會(huì )加1, 記一筆賬 
    3. var our = {wallet: 200} 
    4. var con = 0 
    5.  
    6. // 這個(gè)月,我們喝了四次透心涼心飛揚,每次的消費我們都會(huì )記上一筆 
    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++ 

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

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

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

    因為我們對目標對象的屬性操作改為了對代理對象相同的屬性操作,所以就需要我們在最后通過(guò)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.         // 通過(guò)Reflact對象觸發(fā)原始目標對象的屬性操作 
    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 

    那我們不禁開(kāi)始思考一個(gè)問(wèn)題:如何取消代理呢?

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

    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)行消費記賬 
    15. p.wallet = 197 
    16. p.wallet = 194 
    17. p.wallet = 191 
    18.  
    19. // 某一天,我們實(shí)現了一個(gè)小目標 
    20. p.wallet = 100000000 
    21. // 我們不再需要記賬,取消之前創(chuàng )建的代理 
    22. prevoke() // 執行prevoke即可 
    23.  
    24. p.wallet = 99999997 // 會(huì )顯示報錯 (代理取消就不能再使用) 

     

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

    更多內容

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

    THE END  

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

    1 您的年齡

    2 您的學(xué)歷

    3 您更想做哪個(gè)方向的工作?

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

    快速通道fast track

    近期開(kāi)班時(shí)間TIME

    两个人在线观看免费播放_国产精品天干天干_亚洲婷婷月色婷婷五月小蛇_男人的好小说全文免费阅读