동적 getter 및 setter를 구현하기 위해 JavaScript의 프록시 개체를 어떻게 사용할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-11-02 22:10:03
원래의
833명이 탐색했습니다.

How can JavaScript's Proxy Object be used to implement dynamic getters and setters?

JavaScript에서 동적 Getters/Setter 구현

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿