Introduction :
JavaScript offre des mécanismes flexibles pour l'accès et la modification des propriétés via des getters et passeurs. S'il est bien connu de définir des getters et des setters pour des noms de propriétés prédéterminés, une question se pose : est-il possible d'implémenter des getters et des setters dynamiques qui s'appliquent à des noms de propriétés non définis ?
Gutters dynamiques et Setters utilisant des proxys (ES6) :
Depuis ES2015, JavaScript a introduit des proxys, qui permettent la création d'objets agissant comme des « façades » pour d'autres objets. Cela permet l'interception et la modification des opérations de propriété, y compris les getters et setters.
Exemple :
L'extrait de code suivant illustre des getters et setters dynamiques utilisant des proxys :
<code class="javascript">"use strict"; if (typeof Proxy == "undefined") { throw new Error("This browser doesn't support Proxy"); } let original = { example: "value", }; let proxy = new Proxy(original, { get(target, name, receiver) { if (Reflect.has(target, name)) { let rv = Reflect.get(target, name, receiver); if (typeof rv === "string") { rv = rv.toUpperCase(); } return rv; } return "missing"; } }); console.log(`original.example = ${original.example}`); // "original.example = value" console.log(`proxy.example = ${proxy.example}`); // "proxy.example = VALUE" console.log(`proxy.unknown = ${proxy.unknown}`); // "proxy.unknown = missing" original.example = "updated"; console.log(`original.example = ${original.example}`); // "original.example = updated" console.log(`proxy.example = ${proxy.example}`); // "proxy.example = UPDATED"</code>
Dans cet exemple :
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!