电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript中的Proxy對(duì)象

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

Js中Proxy對(duì)象

Proxy對(duì)象用于定義基本操作的自定義行為,例如屬性查找、賦值、枚舉、函數(shù)調(diào)用等。

語法

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

描述

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

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是用于監(jiān)聽屬性,而Proxy是監(jiān)聽整個(gè)對(duì)象,通過調(diào)用new Proxy(),可以創(chuàng)建一個(gè)代理用來替代另一個(gè)對(duì)象被稱為目標(biāo),這個(gè)代理對(duì)目標(biāo)對(duì)象進(jìn)行了虛擬,因此該代理與該目標(biāo)對(duì)象表面上可以被當(dāng)作同一個(gè)對(duì)象來對(duì)待。代理允許攔截在目標(biāo)對(duì)象上的底層操作,而這原本是Js引擎的內(nèi)部能力,攔截行為使用了一個(gè)能夠響應(yīng)特定操作的函數(shù),即通過Proxy去對(duì)一個(gè)對(duì)象進(jìn)行代理之后,我們將得到一個(gè)和被代理對(duì)象幾乎完全一樣的對(duì)象,并且可以從底層實(shí)現(xiàn)對(duì)這個(gè)對(duì)象進(jìn)行完全的監(jiān)控。

// 常見的一道面試題 實(shí)現(xiàn) a===1&&a===2&&a===3 為true// Object.defineProperty 定義的是屬性// 可以實(shí)現(xiàn)對(duì)于題目的要求var _a = 0;Object.defineProperty(window, 'a', { get:function(){ return ++_a; }})console.log(a===1 && a===2 && a===3); // true// proxy 代理的是對(duì)象 // 因此在調(diào)用時(shí)實(shí)際與題目要求并不太相符// 但同樣也是一種實(shí)現(xiàn)方式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()方法可以用來創(chuàng)建一個(gè)可撤銷的代理對(duì)象,其返回一個(gè)包含了代理對(duì)象本身和它的撤銷方法的可撤銷Proxy對(duì)象。

target: 將用Proxy封裝的目標(biāo)對(duì)象,可以是任何類型的對(duì)象,包括原生數(shù)組,函數(shù),甚至可以是另外一個(gè)代理對(duì)象。 handler: 一個(gè)對(duì)象,其屬性是一批可選的函數(shù),這些函數(shù)定義了對(duì)應(yīng)的操作被執(zhí)行時(shí)代理的行為。

該方法的返回值是一個(gè)對(duì)象,其結(jié)構(gòu)為{'proxy': proxy, 'revoke': revoke},一旦某個(gè)代理對(duì)象被撤銷,它將變得幾乎完全不可調(diào)用,在它身上執(zhí)行任何的可代理操作都會(huì)拋出TypeError異常,注意可代理操作一共有14種,執(zhí)行這14種操作以外的操作不會(huì)拋出異常。一旦被撤銷,這個(gè)代理對(duì)象便不可能被直接恢復(fù)到原來的狀態(tài),同時(shí)和它關(guān)聯(lián)的目標(biāo)對(duì)象以及處理器對(duì)象都有可能被垃圾回收掉。再次調(diào)用撤銷方法revoke()則不會(huì)有任何效果,但也不會(huì)報(bào)錯(cuò)。

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',因?yàn)?typeof 不屬于可代理操作

handler對(duì)象方法

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

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(): 屬性設(shè)置操作的捕捉器。 handler.deleteProperty(): delete操作符的捕捉器。 handler.ownKeys(): Reflect.ownKeys、Object.getOwnPropertyNames、Object.keys、Object.getOwnPropertySymbols方法的捕捉器。 handler.apply(): 函數(shù)調(diào)用操作的捕捉器。 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對(duì)象的詳細(xì)內(nèi)容,更多關(guān)于JavaScript Proxy對(duì)象的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 卫浴散热器,卫浴暖气片,卫生间背篓暖气片,华圣格浴室暖气片 | 硬质合金模具_硬质合金非标定制_硬面加工「生产厂家」-西迪技术股份有限公司 | 金环宇|金环宇电线|金环宇电缆|金环宇电线电缆|深圳市金环宇电线电缆有限公司|金环宇电缆集团 | 智能楼宇-楼宇自控系统-楼宇智能化-楼宇自动化-三水智能化 | 碳纤维复合材料制品生产定制工厂订制厂家-凯夫拉凯芙拉碳纤维手机壳套-碳纤维雪茄盒外壳套-深圳市润大世纪新材料科技有限公司 | 浇钢砖,流钢砖_厂家价低-淄博恒森耐火材料有限公司 | 铣刨料沥青破碎机-沥青再生料设备-RAP热再生混合料破碎筛分设备 -江苏锡宝重工 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 锯边机,自动锯边机,双面涂胶机-建业顺达机械有限公司 | 济南拼接屏_山东液晶拼接屏_济南LED显示屏—维康国际官网 | 档案密集架_电动密集架_移动密集架_辽宁档案密集架-盛隆柜业厂家现货批发销售价格公道 | 高尔夫球杆_高尔夫果岭_高尔夫用品-深圳市新高品体育用品有限公司 | 邢台人才网_邢台招聘网_邢台123招聘【智达人才网】 | 讲师宝经纪-专业培训机构师资供应商_培训机构找讲师、培训师、讲师经纪就上讲师宝经纪 | 液压升降货梯_导轨式升降货梯厂家_升降货梯厂家-河南东圣升降设备有限公司 | 定制液氮罐_小型气相液氮罐_自增压液氮罐_班德液氮罐厂家 | 北京普辉律师事务所官网_北京律师24小时免费咨询|法律咨询 | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 懂研帝_专业SCI论文润色机构_SCI投稿发表服务公司 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | ET3000双钳形接地电阻测试仪_ZSR10A直流_SXJS-IV智能_SX-9000全自动油介质损耗测试仪-上海康登 | 首页_中夏易经起名网| 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 膜结构停车棚-自行车棚-膜结构汽车棚加工安装厂家幸福膜结构 | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 扬子叉车厂家_升降平台_电动搬运车|堆高车-扬子仓储叉车官网 | 蒸压釜-陶粒板隔墙板蒸压釜-山东鑫泰鑫智能装备有限公司 | 斗式提升机,斗式提升机厂家-淄博宏建机械有限公司 | 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂_帽子厂_浙江高普制帽厂 | 工业废水处理|污水处理厂|废水治理设备工程技术公司-苏州瑞美迪 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 立刷【微电签pos机】-嘉联支付立刷运营中心 | 济南网站建设_济南网站制作_济南网站设计_济南网站建设公司_富库网络旗下模易宝_模板建站 | 科普仪器菏泽市教育教学仪器总厂| 科普仪器菏泽市教育教学仪器总厂 | 注塑_注塑加工_注塑模具_塑胶模具_注塑加工厂家_深圳环科 | 亚克隆,RNAi干扰检测,miRNA定量检测-上海基屹生物科技有限公司 | 微学堂-电动能源汽车评测_电动车性能分享网 | 球磨机 选矿球磨机 棒磨机 浮选机 分级机 选矿设备厂家 | 西门子气候补偿器,锅炉气候补偿器-陕西沃信机电工程有限公司 |