1. What is Proxy?The Proxy object is used to intercept and modify specified operations of the target object. // Syntax const p = new Proxy(target, handler)
2. How to use it?1. Simple example of using ProxyAccessing a non-existent property, set the default value to return instead of undefined // 1. Find a suitable handler and write code const handler = { get: function(obj, prop) { return prop in obj ? obj[prop] : 37; } }; // 2. Create a new Proxy object const p = new Proxy({}, handler); // 3. Execute operation pa = 1; pb = undefined; // 4. Check the results console.log(pa, pb); // 1, undefined console.log('c' in p, pc); // false, 37 2. The target object is modified correctlylet target = {}; let p = new Proxy(target, {}); pa = 37; // The operation is forwarded to the target console.log(target.a); // 37. The operation has been forwarded correctly 3. Use set handler for data validationlet validator = { set: function(obj, prop, value) { if (prop === 'age') { if (!Number.isInteger(value)) { throw new TypeError('The age is not an integer'); } if (value > 200) { throw new RangeError('The age seems invalid'); } } // The default behavior to store the value obj[prop] = value; // Indicates success return true; } }; let person = new Proxy({}, validator); person.age = 100; console.log(person.age); // 100 person.age = 'young'; // Throws an exception: Uncaught TypeError: The age is not an integer person.age = 300; // Throws an exception: Uncaught RangeError: The age seems invalid 4. Extended Constructorfunction extend(sup, base) { var descriptor = Object.getOwnPropertyDescriptor( base.prototype, "constructor" ); base.prototype = Object.create(sup.prototype); var handler = { construct: function(target, args) { var obj = Object.create(base.prototype); this.apply(target, obj, args); return obj; }, apply: function(target, that, args) { sup.apply(that, args); base.apply(that, args); } }; var proxy = new Proxy(base, handler); descriptor.value = proxy; Object.defineProperty(base.prototype, "constructor", descriptor); return proxy; } var Person = function (name) { this.name = name }; var Boy = extend(Person, function (name, age) { this.age = age; }); Boy.prototype.sex = "M"; var Peter = new Boy("Peter", 13); console.log(Peter.sex); // "M" console.log(Peter.name); // "Peter" console.log(Peter.age); // 13 SummarizeThis article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM! You may also be interested in:
|
<<: Font references and transition effects outside the system
>>: Introduction to encryption of grub boot program in Linux
Web page encoding is translated into English as we...
I recently used Docker to upgrade a project. I ha...
Table of contents 1. New usage of watch 1.1. Watc...
Transtion in vue is an animation transition enca...
<br />Related articles: 9 practical suggesti...
Table of contents What is a mind map? How to draw...
template <el-table :data="dataList"&...
1. Flex layout .father { display: flex; justify-c...
Table of contents SQL execution order bin log Wha...
Preface Many years ago, I was a newbie on the ser...
We implement a red image style for the clicked bu...
1. Error error connecting to master 'x@xxxx:x...
Preface The docker image cannot be deleted. Check...
This article shares the specific code of js to im...
Mouse effects require the use of setTimeout to ge...