이 기사의 내용은 ES6의 프록시란 무엇입니까? Proxy에 대한 자세한 분석은 특정 참고 가치가 있습니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
프록시는 중국어로 대행사를 의미합니다. 이 단어는 다른 프로그래밍 언어에서도 비슷한 의미를 갖습니다.
Proxy는 생성자입니다. js의 생성자의 일반적인 특징은 첫 글자가 대문자라는 것입니다. 새로운 Proxy(원본 객체, {proxy list}) 형식으로 객체를 생성합니다. 생성된 객체를 프록시 객체라고 합니다.
즉,
프록시 객체 = 새 프록시(원본 객체, {프록시 목록})
이러한 추가 프록시 객체가 생성되는 이유는 원본 객체를 변경하지 않고 그대로 유지할 수 있고, 새로운 기능을 추가할 수 있기 때문입니다. 프록시 객체, 또는 특정 기능을 수정하는 것입니다. 원본 객체는 적절한 시점에 롤백될 수 있습니다. 디자인 패턴 중 에이전트 패턴과 비교하고 이해할 수 있다.
var obj; var proxyObj = new Proxy(obj, { 对obj的操作1: 函数1, 对obj的操作2: 函数2, ... })
var obj = {name:'fan',age:34} console.info(obj.name) var proxyObj = new Proxy(obj,{ get:function(target,key,receiver){console.info(target,key,receiver); return 'no'} }) console.info(proxyObj.name) console.info(proxyObj.abc)
의 기본 데모는 다음과 같이 설명됩니다.
Proxxy 객체는 obj 객체를 기반으로 생성된 새로운 객체입니다.
proxyObj.name은 프록시 개체의 이름 속성을 가져오는 것입니다. .연산자가 자동으로 get() 메서드를 호출합니다
. 이는 매우 중요합니다. js에서 객체는 순서가 지정되지 않은 속성 모음입니다. 객체에는 속성만 있고 다른 것은 없습니다
그리고 우리는 종종 객체의 특정 메서드를 호출하는 것에 대해 이야기합니다. 예를 들어 배열 객체 arr의 정렬 메서드: arr.sort()도 여기서의 정렬입니다. arr 객체의 속성(더 엄밀하게 말하면 sort는 arr.__proto__ 객체의 속성입니다.) length 속성과 비교하면 sort 속성의 속성값은 함수이므로 이 함수를 실행하려면 뒤에 ()를 추가하세요. , 길이 속성의 값은 숫자값이므로 ()를 추가하지 않고 바로 사용 가능합니다. 다시 강조하겠습니다: 객체의 . 연산은 자동으로 get
을 호출합니다. 물론 우리가 일반적으로 사용할 때에는 이 사실을 깨닫지 못합니다. .操作符会自动去调用get()方法
。这一点非常重要,在js中,对象是属性的无序集合。对象只有属性,其他什么都没有
. 而我们经常说的调用对象的某个方法:例如数组对象arr的sort方法:arr.sort(),这里的sort也是arr对象的属性(更严谨一点,sort是arr.__proto__这个对象的属性),与length属性相比,sort属性的属性值是一个函数,所以在它的后面加()来执行这个函数,而length属性的值是一个数值,所以不需要加()就可以直接使用。再次强调一下:对象的.操作,会自动去调用get
。当然,我们平时使用.操作时,是没有感知到这一点的。
在new Proxy的第二个参数中,明确设置了get的方法:当访问proxyObj的任意属性时,输出target,key,receiver的值,并统一返回no。所以proxyObj.name和proxyObj.abc都会得到no。
写到这里你会觉得原对象与代理对象之间有什么关系呢?为什么叫代理
에이전트
라고 부르나요? 에이전트의 역할을 이해하세요外界 <----> 原对象; 外界 <----> 代理对象 <------> 原对象;
var obj = {name:'fan',age:34} console.info(obj.age) // 34 var proxyObj = new Proxy(obj,{ get:function(target,key,receiver){ console.info(target === obj); //true console.info(receiver === proxyObj); //true if('age' === key){ return target[key] - 5; } else{ return target[key] } } }) console.info(proxyObj.age) // 34- 5 = 29
프록시 객체와 원본 객체의 관계
var arr = [2,1] var proxyArr = new Proxy(arr,{} ) proxyArr.push(3); console.info(arr) // [2,1,3] console.info(arr === proxyArr) // false arr.sort(); console.info(proxyArr[0]) // 1
위 코드에서 이 프록시 객체는 특별한 작업을 수행하지 않습니다. 연예인의 매니저들은 외부 세계의 정보를 연예인 자신에게 전달하는 등 소극적인 업무를 수행하는 것으로 이해된다. 따라서 ProxyArr에서 수행되는 작업은 arr에 직접적인 영향을 미칩니다.
proxyArr.__proto__ === arr.__proto__ === Array.prototype
var proxyObj = new Proxy(obj, { get: function(tagert,key,receiver){}, set: function(tagert,key,receiver){}, has: function(tagert,key){}, deleteProperty: function(tagert,key){}, ownKeys: function(tagert){}, getOwnPropertyDescriptor: function(tagert,key){}, defineProperty: function(tagert,key,desc){}, preventExtensions: function(tagert){}, getPrototypeOf: function(tagert){}, isExtensible: function(tagert){}, setPrototypeof: function(tagert,proto){}, apply: function(tagert,obj,args){}, construct: function(tagert,args){}, })
var arr = [1,2,3]; console.info(arr[0]) // 1 console.info(arr[-1]) // undefined console.info(arr[100]) // undefined
var arr = [1,2,3]; var proxyArr = new Proxy(arr,{ get: (target,prop)=>{ let index = Number(prop); if(index < 0){ prop = target.length + index; } return target[prop]; } }) console.info(arr[-1]); // undefined console.info(proxyArr[-1]); // 3
function myArr(...args){ var arr = new Array(...args); var proxyArr = new Proxy(arr,{ get: (target,key)=>{ let index = Number(key); if(index < 0){ key = target.length + index; } return target[key]; } }) return proxyArr; } var obj = myArr([1,2,3]); console.info(obj[0],obj[-1])
var double = n => n*2; var pow2 = n => n*n; var half = n => n/ 2; var add1 = n => n+1; function pipe (num){ let funs = [] let obj = new Proxy({},{ get:function(target,prop){ if(prop === 'end'){ return funs.reduce((val,currentfn)=>currentfn(val),num); }else{ funs.push(window[prop]) } return obj; } }) return obj; }; console.info( pipe(4).double.pow2.end); console.info( pipe(4).pow.double.pow2.add1.end);
위 내용은 ES6의 프록시란 무엇입니까? Proxy에 대한 상세 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!