>웹 프론트엔드 >JS 튜토리얼 >JavaScript는 예측할 수 없는 속성에 대한 동적 Getter 및 Setter를 구현할 수 있습니까?

JavaScript는 예측할 수 없는 속성에 대한 동적 Getter 및 Setter를 구현할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-29 18:04:02213검색

 Can JavaScript Implement Dynamic Getters and Setters for Unpredictable Properties?

JavaScript에서 동적 Getters/Setter를 구현할 수 있나요?

동적 getter 및 setter를 사용하면 JavaScript 객체가 사전 정의된 속성 이상의 속성 액세스 및 수정을 처리할 수 있습니다. 이전 JavaScript 기술에서는 알려진 속성에 대해 특정 getter 및 setter를 사용했지만 이 기사에서는 정의되지 않은 속성에 대해 포괄적인 getter 및 setter 구현 가능성을 살펴봅니다.

ES2015 프록시: 동적 솔루션

ES2015에서는 다른 객체의 중개자 역할을 하는 객체 생성을 가능하게 하는 JavaScript 프록시를 도입했습니다. 이 기능은 동적 getter 및 setter를 엽니다.

<code class="js">const original = {
    example: "value",
};
const 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(`proxy.example = ${proxy.example}`); // "proxy.example = VALUE"
console.log(`proxy.unknown = ${proxy.unknown}`); // "proxy.unknown = missing"</code>

이 예에서 프록시 개체는 원본 개체에 대한 속성 액세스를 가로챕니다. 문자열 속성에 액세스할 때 프록시는 이를 대문자로 변환하여 반환합니다. 알 수 없는 속성의 경우 정의되지 않음 대신 "누락"을 반환합니다.

이 구현은 브라우저가 ES2015(ES6)를 지원하는 경우 브라우저 간 호환됩니다. 이전 브라우저의 경우 폴리필이나 대체 기술을 사용하는 것이 좋습니다. 프록시는 동적 getter 및 setter를 위한 유연한 솔루션을 제공하여 원본 객체를 수정하지 않고도 효율적인 속성 처리 및 속성 검사를 가능하게 합니다.

위 내용은 JavaScript는 예측할 수 없는 속성에 대한 동적 Getter 및 Setter를 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.