日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript中的Proxy對象

瀏覽:170日期:2023-10-07 09:54:15

Js中Proxy對象

Proxy對象用于定義基本操作的自定義行為,例如屬性查找、賦值、枚舉、函數調用等。

語法

const proxy = new Proxy(target, handler); target: 要使用Proxy包裝的目標對象,可以是任何類型的對象,包括原生數組,函數,甚至另一個代理。 handler: 一個通常以函數作為屬性的對象,各屬性中的函數分別定義了在執行各種操作時代理proxy的行為。

描述

Proxy用于修改某些操作的默認行為,也可以理解為在目標對象之前架設一層攔截,外部所有的訪問都必須先通過這層攔截,因此提供了一種機制,可以對外部的訪問進行過濾和修改。這個詞的原理為代理,在這里可以表示由它來代理某些操作,譯為代理器。

var target = {a: 1};var proxy = new Proxy(target, { set: function(target, key, value, receiver){ console.log('watch'); return Reflect.set(target, key, value, receiver); }, get: function(target, key, receiver){ return target[key]; }});proxy.a = 11; // watchconsole.log(target); // {a: 11}

Object.defineProperty是用于監聽屬性,而Proxy是監聽整個對象,通過調用new Proxy(),可以創建一個代理用來替代另一個對象被稱為目標,這個代理對目標對象進行了虛擬,因此該代理與該目標對象表面上可以被當作同一個對象來對待。代理允許攔截在目標對象上的底層操作,而這原本是Js引擎的內部能力,攔截行為使用了一個能夠響應特定操作的函數,即通過Proxy去對一個對象進行代理之后,我們將得到一個和被代理對象幾乎完全一樣的對象,并且可以從底層實現對這個對象進行完全的監控。

// 常見的一道面試題 實現 a===1&&a===2&&a===3 為true// Object.defineProperty 定義的是屬性// 可以實現對于題目的要求var _a = 0;Object.defineProperty(window, 'a', { get:function(){ return ++_a; }})console.log(a===1 && a===2 && a===3); // true// proxy 代理的是對象 // 因此在調用時實際與題目要求并不太相符// 但同樣也是一種實現方式var _a = 0;var proxy = new Proxy(window, { set: function(target, key, value, receiver){ return Reflect.set(target, key, value, receiver); }, get: function(target, key, receiver){ if(key === 'a') return ++_a; else return window[key]; }});console.log(proxy.a===1 && proxy.a===2 && proxy.a===3); //true

方法

Proxy.revocable()

Proxy.revocable(target, handler)Proxy.revocable()方法可以用來創建一個可撤銷的代理對象,其返回一個包含了代理對象本身和它的撤銷方法的可撤銷Proxy對象。

target: 將用Proxy封裝的目標對象,可以是任何類型的對象,包括原生數組,函數,甚至可以是另外一個代理對象。 handler: 一個對象,其屬性是一批可選的函數,這些函數定義了對應的操作被執行時代理的行為。

該方法的返回值是一個對象,其結構為{'proxy': proxy, 'revoke': revoke},一旦某個代理對象被撤銷,它將變得幾乎完全不可調用,在它身上執行任何的可代理操作都會拋出TypeError異常,注意可代理操作一共有14種,執行這14種操作以外的操作不會拋出異常。一旦被撤銷,這個代理對象便不可能被直接恢復到原來的狀態,同時和它關聯的目標對象以及處理器對象都有可能被垃圾回收掉。再次調用撤銷方法revoke()則不會有任何效果,但也不會報錯。

var revocable = Proxy.revocable({}, { get: function(target, key) { return `[[ ${key} ]]`; }});var proxy = revocable.proxy;console.log(proxy.example); // [[ example ]]revocable.revoke();// console.log(proxy.example); // 拋出 TypeError// proxy.example = 1; // 拋出 TypeError// delete proxy.example; // 拋出 TypeError// typeof proxy // 'object',因為 typeof 不屬于可代理操作

handler對象方法

handler對象是一個容納一批特定屬性的占位符對象,它包含有Proxy的各個捕獲器trap。所有的捕捉器是可選的,如果沒有定義某個捕捉器,那么就會保留源對象的默認行為。

handler.getPrototypeOf(): Object.getPrototypeOf方法的捕捉器。 handler.setPrototypeOf(): Object.setPrototypeOf方法的捕捉器。 handler.isExtensible(): Object.isExtensible方法的捕捉器。 handler.preventExtensions(): Object.preventExtensions方法的捕捉器。 handler.getOwnPropertyDescriptor(): Object.getOwnPropertyDescriptor方法的捕捉器。 handler.defineProperty(): Object.defineProperty方法的捕捉器。 handler.has(): in操作符的捕捉器。 handler.get(): 屬性讀取操作的捕捉器。 handler.set(): 屬性設置操作的捕捉器。 handler.deleteProperty(): delete操作符的捕捉器。 handler.ownKeys(): Reflect.ownKeys、Object.getOwnPropertyNames、Object.keys、Object.getOwnPropertySymbols方法的捕捉器。 handler.apply(): 函數調用操作的捕捉器。 handler.construct(): new操作符的捕捉器。

var target = { a: 1, f: function(...args){ console.log(...args); }};var proxy = new Proxy(target, { getPrototypeOf: function(target) { console.log('getPrototypeOf'); return Object.getPrototypeOf(target); }, setPrototypeOf: function(target, prototype) { console.log('setPrototypeOf'); return Object.setPrototypeOf(target, prototype); }, isExtensible: function(target) { console.log('isExtensible'); return Object.isExtensible(target); }, preventExtensions: function(target) { console.log('preventExtensions'); return Object.preventExtensions(target); }, getOwnPropertyDescriptor: function(target, prop) { console.log('getOwnPropertyDescriptor'); return Object.getOwnPropertyDescriptor(target, prop); }, defineProperty: function(target, prop, descriptor) { console.log('defineProperty'); return Object.defineProperty(target, prop, descriptor); }, has: function(target, prop) { console.log('has'); return prop in target; }, get: function(target, prop, receiver) { console.log('get'); return target[prop]; }, set: function(target, prop, value, receiver) { console.log('set'); target[prop] = value; return true; }, deleteProperty: function(target, property) { console.log('deleteProperty'); delete target[property]; return true; }, ownKeys: function(target) { console.log('ownKeys'); return Reflect.ownKeys(target); }})var proxyF = new Proxy(target.f, { construct: function(target, argumentsList, newTarget) { console.log('construct'); return new target(...argumentsList); }, apply: function(target, thisArg, argumentsList) { console.log('apply'); return target.apply(thisArg, argumentsList); },})const _prototype = {test: 1};Object.setPrototypeOf(proxy, _prototype); // setPrototypeOfconsole.log(Object.getPrototypeOf(proxy)); // getPrototypeOf // { test: 1 }Object.preventExtensions(proxy); // preventExtensionsconsole.log(Object.isExtensible(proxy)); // isExtensible // falseObject.defineProperty(proxy, 'a', {configurable: true}); // definePropertyconsole.log(Object.getOwnPropertyDescriptor(proxy, 'a')); // getOwnPropertyDescriptor // { value: 1, writable: true, enumerable: true, configurable: true }proxy.a = 11; // setconsole.log(proxy.a); // get // 11console.log(Object.keys(proxy)); // ownKeys getOwnPropertyDescriptor getOwnPropertyDescriptor // [ ’a’, ’f’ ]delete proxy.a; // deletePropertyconsole.log('a' in proxy); // has // falseproxyF(1, 2, 3); // apply 1 2 3new proxyF(1, 2, 3); // construct 1 2 3

每日一題

https://github.com/WindrunnerMax/EveryDay

以上就是JavaScript中的Proxy對象的詳細內容,更多關于JavaScript Proxy對象的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产伦精品一区二区三区千人斩| 国产精品巨作av| 久久久久久夜| 大香伊人久久精品一区二区 | 成人在线免费观看91| 黄色网一区二区| www.九色在线| 国产亚洲在线观看| 欧美午夜三级| 高清久久一区| 亚洲精品va| 日韩一区二区三区四区五区| 国产精品久久国产愉拍| 欧美一区成人| 高清av不卡| 天使萌一区二区三区免费观看| 男人的天堂久久精品| 日韩免费精品| 欧美aa在线观看| 91九色综合| 美女网站一区| 国产精品1区在线| 免费成人网www| 精品一区二区三区四区五区| 国产一区清纯| 久久精品日韩欧美| 免费看黄色91| 成人羞羞视频播放网站| 一区二区电影| 桃色av一区二区| 国产精品中文| 免费日韩视频| 国产三级精品三级在线观看国产| 日韩欧美精品一区二区综合视频| 国产日产精品一区二区三区四区的观看方式 | 午夜国产一区二区| 国产精品s色| 免费视频久久| 中国字幕a在线看韩国电影| 免费成人在线影院| 日韩精品欧美| 久久精品亚洲| 国产欧美91| 日本久久一区| 中文字幕一区二区三区日韩精品| 尤物tv在线精品| 欧美aa在线观看| 中文在线中文资源| 久久久久久夜| 日韩高清欧美| 91av亚洲| 久久国产中文字幕| 欧美va天堂在线| 久久精品99久久无色码中文字幕| 日韩av在线中文字幕| 欧美韩日一区| 国产suv精品一区二区四区视频 | 中文字幕一区二区三区日韩精品 | 偷拍精品精品一区二区三区| 久久精品一区| 高清日韩欧美| 日韩av片子| 欧美日韩激情| 亚洲中午字幕| 亚洲+小说+欧美+激情+另类| 日韩一区精品| 国际精品欧美精品| 波多野结衣久久精品| 久久中文字幕av一区二区不卡| 91精品蜜臀一区二区三区在线| 久久视频精品| 视频一区二区三区在线| 91嫩草精品| 国产精品国产一区| 女人天堂亚洲aⅴ在线观看| 首页国产欧美日韩丝袜| 中文精品在线| 国产九九精品| 免费视频一区三区| 日韩激情中文字幕| 日韩电影在线视频| 在线免费观看亚洲| 国产日韩电影| 亚洲一区二区日韩| 成人国产精品一区二区免费麻豆| 婷婷成人基地| 国产精品黄网站| 亚洲作爱视频| 大香伊人久久精品一区二区 | 国内精品伊人| 蜜臀久久99精品久久久久久9| 久久精品亚洲一区二区| 免费精品视频最新在线| 日本免费久久| 久久国产欧美日韩精品| jiujiure精品视频播放| 精品一区二区三区视频在线播放| 日韩午夜黄色| 日韩精品dvd| 国产精品亚洲二区| 丝袜美腿高跟呻吟高潮一区| 日韩免费小视频| 国产精品一区三区在线观看| 免费国产自线拍一欧美视频| 国模大尺度视频一区二区| 午夜性色一区二区三区免费视频| 日韩精品一区二区三区免费观看| 麻豆精品久久久| 色综合视频一区二区三区日韩| 精品日韩视频| 高清一区二区三区| 久久久久伊人| 国产精品久久久网站| 奇米色欧美一区二区三区| 首页欧美精品中文字幕| 精品日韩毛片| 亚洲激情另类| 宅男噜噜噜66国产日韩在线观看| 久久蜜桃资源一区二区老牛| 欧美激情91| 久久精品免视看国产成人| 国产福利资源一区| 美女久久久久久 | 正在播放日韩精品| 激情黄产视频在线免费观看| 久久精品二区亚洲w码| 麻豆久久一区| 久久影院资源站| 国产视频网站一区二区三区| 国产免费播放一区二区| 里番精品3d一二三区| 国产一区二区三区久久久久久久久| 久久免费影院| 免费污视频在线一区| 欧美日韩高清| 亚洲精品成人一区| 国产精区一区二区| 国产资源在线观看入口av| 欧美午夜精彩| 亚洲精品在线国产| 久久国内精品自在自线400部| 久久精品国产网站| 中文国产一区| 久久国产生活片100| 美女视频一区在线观看| 亚洲二区免费| 久久国产人妖系列| 日韩另类视频| 天堂俺去俺来也www久久婷婷| 美女av一区| 亚洲日本三级| 九色porny丨国产首页在线| 一区二区三区四区在线观看国产日韩| 日韩av中文字幕一区二区三区| 国产在线一区不卡| 日韩精品一二三四| 欧美日韩国产v| 国产欧美91| 99视频在线精品国自产拍免费观看| 欧美综合精品| 午夜av一区| 波多视频一区| 国产精品一区二区精品视频观看| 亚洲国内欧美| 日韩av在线播放网址| 欧美亚洲三级| 亚洲一区二区三区四区五区午夜 | 青青青免费在线视频| 免费精品视频最新在线| 久久久久久自在自线| 国产欧美日韩综合一区在线播放| 亚洲电影在线| 亚洲最新无码中文字幕久久| 国产亚洲电影| 日本不卡一二三区黄网| 亚洲欧洲另类| 久久精品国产大片免费观看| 麻豆极品一区二区三区| 国产精品网站在线看| 日韩福利视频网| 亚洲精品伦理| 亚洲精品裸体| 亚洲精品一级| 日本亚洲视频在线| 男人的天堂久久精品| 日韩在线观看一区二区| 美女精品网站| 亚洲精品女人| 国产精品夜夜夜| 国产精品黄网站| 国产在视频一区二区三区吞精| 精品国产aⅴ| 在线手机中文字幕| 婷婷综合在线| 欧美专区18| 欧美日韩一区二区国产 | 欧美综合另类| 在线亚洲观看| 日韩**一区毛片| 国产欧美亚洲一区|