摘要:用于修改某些操作的默認(rèn)行為和訪問器屬性的行為類似在對象的前面多一層代理,對象字面量中定義屬性的特性方法,訪問器屬性此時屬性被定義為訪問器屬性不一樣的寫法中是用代理的寫法第一個參數(shù)是對象,第二個是要操作的方法對象也有兩個屬性,一個是目標(biāo)對象,
1,Proxy用于修改某些操作的默認(rèn)行為和訪問器屬性的行為類似,在對象的前面多一層代理,
const obj = { //對象字面量 name : "obama", age : 73 } obj.name //obama //ES5中定義屬性的特性方法,訪問器屬性O(shè)bject.defineProperty(); Object.defineProperty(obj,name",{ get :function(){ return "hello presdent"; } }); obj;//{age : 73}此時name屬性被定義為訪問器屬性 obj.name // "hello presdent"; var newObj = { _name : "obama", get name(){ //不一樣的寫法 return "hello presdent"; } } //ES6中是用Proxy代理的寫法 var proxy = new Proxy(targetn,handler(target,property)) //第一個參數(shù)是對象,第二個是要操作的方法對象,也有兩個屬性,一個是目標(biāo)對象,一個是屬性 var obj = { name : "obama", age : 73 }; var fn = { get : function(obj){ alert("hello presdent") } }
Proxy支持的攔截操作
1,get(),用于讀取某個屬性的操作
var person = { name : "obama" }; var proxy = new Proxy(person,{ get : function(target,property){ if(property in target){ return target[property] }else{ throw new ReferenceError("you input wrong property") } } }) proxy.name //obama; proxy.age //Uncaught ReferenceError: you input wrong property person.age //undefind //此屬性可以繼承 var pro = Object.create(proxy); pro.name //obama;
2,set(),用于攔截屬性的賦值操作
var obj = { set : function(obj,prop,value){ if(prop ==="age"){ if(Number.isInteger(value)){ obj[prop] = value; }else{ throw new Error("not a number") } } else{ obj[prop] = value; } } }; var person = new Proxy({},obj); person.age = 12;//12; person.age = "test" //Uncaught Error: not a number //可以使用這個方法不允許訪問內(nèi)部帶有下劃線的變量 function validat(key,action){ if(key[0] === "_"){ throw new Error("不允許訪問內(nèi)部變量") } } var obj = { get(target,key){ validat(key,"get"); return target[key] }, set(target,key,value){ validat(key,"set"); return target[key] = value; } }; var target = {}; var proxy = new Proxy(target,obj);
3,apply()攔截調(diào)用和apply和call操作
4,has()隱藏某些屬性,不被in操作符發(fā)現(xiàn)
var handle = { has(target,key){ if(key[0] === "_"){ return false; } return key in target } }; var obj = { name : "obama" } var proxy = new Proxy(obj,handle);
5,construct()攔截new命令
var Fn = function(){return "the world"}; var handle = { construct : function(){ throw new Error("不能使用NEW操作符") } }; var proxy = new Proxy(Fn,handle); var newp = new proxy;//Uncaught Error: 不能使用NEW操作符 var newp = proxy() //the world //同樣如果返回的不是對象也會報錯
6,deleteProperty()攔截刪除操作,如果返回的不是true就無法刪除
var handle = { deleteProperty(target,key){ return false; //返回錯誤或者false都不能刪除 } }; var obj ={ name : "obama" }; var presdent = new Proxy(obj,handle); delete presdent.name //false;
7,enumerate()攔截for in 循環(huán)
8,getOwnPropertyDescriptor(),
9,getPrototypeOf()
10,isExtensible(),
11,Own.keys()攔截Object.keys()方法
12,preventExtensions();
13,setProtypeOf();
14,Proxy.revocable()返回一個可以取消的Proxy實(shí)例
var handle = {}; var obj = {}; var s= Proxy.revocable(obj,handle);//返回一個對象, s //{proxy: Proxy, revoke: ?} s.proxy.name = "obama"; //obama s.revoke(); s.proxy.name //Uncaught TypeError: Cannot perform "get" on a proxy
Reflect對象,包含一些特殊的屬性,默認(rèn)是對象的原始行為,Proxy改寫的就是這些行為
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88857.html
摘要:我們先以框架出發(fā),探索其中數(shù)據(jù)劫持的奧秘。針對對象在數(shù)據(jù)劫持這個問題上,可以被認(rèn)為是的升級版。技術(shù)支持監(jiān)測數(shù)組的等方法操作,支持對象屬性的動態(tài)添加和刪除,極大的簡化了響應(yīng)化的代碼量。 隨著前端界的空前繁榮,各種框架橫空出世,包括各類mvvm框架百家爭鳴,比如Anglar、Vue、React等等,它們最大的優(yōu)點(diǎn)就是可以實(shí)現(xiàn)數(shù)據(jù)綁定,再也不需要手動進(jìn)行DOM操作了,它們實(shí)現(xiàn)的原理也基本上是...
angular2是什么?我猜不容我贅述,各位一定略有耳聞,無論是曾經(jīng)AngularJS的擁躉,亦或是React的粉絲,都或多或少的對她有過一點(diǎn)了解。未見其物、先聞其聲,angular2在問世之前已經(jīng)做足了宣傳,想必諸位也一定被下面各種詞匯所震懾,什么:TypeScript、 ES5、 ES6、 Dart、 Immutable、 Unidirectional Data Flow、 Reactive ...
摘要:在下文中,首先我會介紹的使用方式,然后列舉具體實(shí)例解釋的使用場景。如果簡單地區(qū)分和的使用場景,可以概括為的核心作用是控制外界對被代理者內(nèi)部的訪問,的核心作用是增強(qiáng)被裝飾者的功能。 文章永久鏈接地址:http://pinggod.com/2016/%E5%AE%9E%E4%BE%8B%E8%A7%A3%E6%9E%90-ES6-Proxy-%E4%BD%BF%E7%94%A8%E5%9C...
摘要:原始的數(shù)據(jù)類型和一樣是第七種數(shù)據(jù)類型創(chuàng)建只能用函數(shù)來創(chuàng)建,而且不能用可以有參數(shù),用來區(qū)分每個只能顯試的轉(zhuǎn)化此處是字符串不能在轉(zhuǎn)為數(shù)字報錯不能隱式的轉(zhuǎn)化報錯作為對象的的屬性名稱主要用在可計(jì)算的屬性名稱,即使帶有中括號的屬性名稱一般是私有不可以 Symbol原始的數(shù)據(jù)類型和string, boolean,null,undefined,number一樣,是JS第七種數(shù)據(jù)類型 //創(chuàng)建Symb...
摘要:我們使用了模式書寫,并引入了思想,這些以前只在里見到的設(shè)計(jì),現(xiàn)在里也有體現(xiàn),并且在本章中會著重講解多的協(xié)作。如果之前寫過,那對于這種書寫方式一定無比熟悉。每次數(shù)據(jù)的變更,無論是還是,都將變化冒泡到,然后由再向下逐級推送各組件是否重繪。 前集回顧 在上一章里我們講了如何在angular2下開發(fā)一個component(還沒做的趕緊去學(xué)吧)。我們使用了Unidirectional Data ...
閱讀 2495·2021-10-19 11:45
閱讀 2485·2021-09-30 09:56
閱讀 1441·2021-09-30 09:47
閱讀 599·2019-08-30 15:53
閱讀 1840·2019-08-30 15:44
閱讀 589·2019-08-30 12:52
閱讀 1091·2019-08-30 11:16
閱讀 1616·2019-08-29 16:36