Heim >Web-Frontend >js-Tutorial >Die Macht des Stellvertreters

Die Macht des Stellvertreters

WBOY
WBOYOriginal
2024-09-05 22:34:33571Durchsuche

The Power of Proxy

Proxy-Objekt ist eine der leistungsstärksten, aber am wenigsten genutzten Funktionen in JavaScript!

Es ermöglicht Ihnen die vollständige Kontrolle über das Verhalten Ihrer Objekte in JavaScript, indem Sie benutzerdefiniertes Verhalten für grundlegende Vorgänge an Objekten definieren, wie z. B. das Abrufen oder Festlegen von Eigenschaften.

Es kann auch zum Erstellen einer benutzerdefinierten Validierung, Datenbindung, Protokollierung oder sogar zum Erstellen vollständig reaktiver Objekte verwendet werden – ohne dass eine Bibliothek erforderlich ist!

Hier ist ein einfaches Beispiel:

const user = {
  name: 'Zain',
  age: 22
};

const handler = {
  get: (target, prop) => {
    console.log(`Getting property ${prop}`);
    return prop in target ? target[prop] : 'Property does not exist';
  },
  set: (target, prop, value) => {
    if (prop === 'age' && typeof value !== 'number') {
      console.log('Invalid age type. It should be a number.');
    } else {
      console.log(`Setting property ${prop} to ${value}`);
      target[prop] = value;
    }
    return true;
  }
};

const proxiedUser = new Proxy(user, handler);

console.log(proxiedUser.name); // Logs: Getting property name
proxiedUser.age = 'twenty-two'; // Logs: Invalid age type. It should be a number.
proxiedUser.age = 23; // Logs: Setting property age to 23

Mit Proxy können Sie nahezu jedes grundlegende Verhalten von Objekten abfangen und neu definieren – und so eine Ebene der Kontrolle und Anpassung hinzufügen, die von keiner anderen Funktion in JavaScript erreicht wird!


Um über weitere Inhalte rund um Webentwicklung und KI auf dem Laufenden zu bleiben, folgen Sie mir gerne. Lasst uns gemeinsam lernen und wachsen!

Das obige ist der detaillierte Inhalt vonDie Macht des Stellvertreters. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn