JavaScript에서 사전 정의된 속성에 대한 getter 및 setter를 생성하는 방법을 이해하는 것은 일반적인 개념입니다. 그러나 명시적으로 정의되지 않은 속성 이름의 동적 처리를 포함하도록 이 기능을 확장하는 것은 고유한 문제를 야기합니다.
PHP의 동적 Getter 및 Setter 기능
PHP는 모든 속성에 대한 getter 및 setter 동작을 동적으로 정의하는 __get() 및 __set() 매직 메서드. 이는 즉시 속성을 조작할 수 있는 편리하고 유연한 접근 방식을 제공합니다.
구조를 위한 JavaScript의 프록시
ES2015부터 JavaScript는 동적 getter 및 setter 구현. 프록시를 사용하면 다른 개체에 대한 파사드 역할을 하는 개체를 생성하여 속성 액세스를 가로채고 수정할 수 있습니다.
동적 Getters/Setters에 프록시를 사용하는 예
존재하지 않는 모든 속성 값이 "누락"을 반환하고 문자열 속성 값이 검색 시 대문자로 변환되는 다음 예를 고려해 보겠습니다.
<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"; } });</code>
동적 동작 테스트
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 = 누락"
original.example = "updated";
console.log(original.example = ${original.example}); // "original.example = 업데이트됨"
console.log(proxy.example = ${proxy.example}); // "proxy.example = UPDATED"
설명된 것처럼 프록시는 속성 액세스를 가로채고 존재하지 않는 속성("누락") 및 문자열 속성(대문자 변환)에 대해 정의된 동작을 적용합니다. 또한 변경 사항을 반영하는 프록시를 사용하여 원본 개체를 수정할 수 있습니다.
브라우저 호환성
프록시는 Chrome, Firefox를 포함한 모든 주요 최신 브라우저에서 지원됩니다. , Edge, Safari 및 Internet Explorer 11.
위 내용은 동적 getter 및 setter를 구현하기 위해 JavaScript의 프록시 개체를 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!