Detailed explanation of JavaScript Proxy object

Detailed explanation of JavaScript Proxy object

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)
  • target : The target object (can be any type of object, including a native array, a function, or even another proxy).
  • handler: An object with functions as attributes to implement interception and custom operations.

2. How to use it?

1. Simple example of using Proxy

Accessing 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 correctly

let 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 validation

let 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 Constructor

function 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

Summarize

This 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:
  • Proxy Object in JavaScript
  • Detailed explanation of the principle of js Proxy
  • JS takes you deep into the world of Proxy
  • Specific use of ES6 Proxy in JavaScript
  • What interesting things can JavaScript Proxy do?

<<:  Font references and transition effects outside the system

>>:  Introduction to encryption of grub boot program in Linux

Recommend

How to install Docker on Windows 10 Home Edition

I recently used Docker to upgrade a project. I ha...

New usage of watch and watchEffect in Vue 3

Table of contents 1. New usage of watch 1.1. Watc...

Summary of the application of transition components in Vue projects

​Transtion in vue is an animation transition enca...

9 Tips for Web Page Layout

<br />Related articles: 9 practical suggesti...

How to draw a mind map in a mini program

Table of contents What is a mind map? How to draw...

Vue event's $event parameter = event value case

template <el-table :data="dataList"&...

Summary of MySQL log related knowledge

Table of contents SQL execution order bin log Wha...

How to use VUE to call Ali Iconfont library online

Preface Many years ago, I was a newbie on the ser...

Explanation of the precautions for Mysql master-slave replication

1. Error error connecting to master 'x@xxxx:x...

Docker image cannot be deleted Error: No such image: xxxxxx solution

Preface The docker image cannot be deleted. Check...

js to realize a simple puzzle game

This article shares the specific code of js to im...

JavaScript to achieve mouse tailing effect

Mouse effects require the use of setTimeout to ge...