Maison >interface Web >js tutoriel >Un proxy en JavaScript

Un proxy en JavaScript

王林
王林original
2024-07-19 19:15:37420parcourir

A Proxy in JavaScript

Un proxy en JavaScript est un objet spécial qui vous permet de personnaliser le comportement des opérations fondamentales (par exemple, recherche de propriété, affectation, énumération, appel de fonction, etc.) sur un autre objet. C'est comme avoir un intermédiaire espiègle qui peut intercepter et modifier les interactions avec un objet.

Pourquoi avons-nous besoin de procurations ?

Les proxys sont utiles pour diverses raisons :

  1. Validation : Garantir l'intégrité des données en validant les affectations.
    Journalisation : suivez les opérations sur un objet pour le débogage ou la surveillance.

  2. Valeurs par défaut : Fournissez les valeurs par défaut lors de l'accès aux propriétés.

  3. Contrôle d'accès : Restreindre ou modifier l'accès à certaines propriétés.

  4. Propriétés virtuelles : Définissez des propriétés qui n'existent pas physiquement sur l'objet.

Exemples amusants pour comprendre les proxys

Exemple 1 : le parent surprotecteur

Imaginez que vous avez un enfant nommé Timmy et que vous voulez vous assurer qu'il ne mange pas trop de cookies. Vous agissez comme un parent surprotecteur, surveillant et contrôlant sa consommation de cookies.

let timmy = {
  cookies: 3
};

let overprotectiveParent = new Proxy(timmy, {
  get(target, property) {
    console.log(`Overprotective Parent: "Timmy currently has ${target[property]} ${property}."`);
    return target[property];
  },
  set(target, property, value) {
    if (property === 'cookies' && value > 5) {
      console.log('Overprotective Parent: "No, Timmy, you can’t have more than 5 cookies!"');
      return false;
    }
    console.log(`Overprotective Parent: "Alright, Timmy, you can have ${value} ${property}."`);
    target[property] = value;
    return true;
  }
});

// Checking Timmy's cookies
console.log(overprotectiveParent.cookies); // Overprotective Parent: "Timmy currently has 3 cookies."

// Trying to give Timmy too many cookies
overprotectiveParent.cookies = 6; // Overprotective Parent: "No, Timmy, you can’t have more than 5 cookies!"

// Setting a reasonable number of cookies
overprotectiveParent.cookies = 4; // Overprotective Parent: "Alright, Timmy, you can have 4 cookies."
console.log(overprotectiveParent.cookies); // Overprotective Parent: "Timmy currently has 4 cookies."

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn