JavaScript: 객체 리터럴을 사용하여 자체 함수 내의 키 참조
문제:
객체를 사용할 때 JavaScript의 리터럴에는 객체의 속성에 대해 작동하는 함수를 포함하는 것이 일반적입니다. 그러나 해당 함수 내에서 개체를 참조하는 방법에는 두 가지가 있습니다. 이를 사용하거나 개체 리터럴 이름을 명시적으로 사용하는 것입니다. 이 기사에서는 각 접근 방식의 의미를 살펴봅니다.
해결책:
사용 방법:
var obj = {
key1: "it",
key2: function(){return this.key1 + " works!"}
};
- 이를 사용하여 함수 내의 개체를 참조하면 함수가 어떻게 개체를 참조하는지에 관계없이 항상 올바른 개체에 액세스할 수 있습니다.
- 그러나 함수가 객체에서 추출되는 경우(예: 변수에 할당되거나 인수로 전달되는 경우) 예상대로 객체를 참조하지 않을 수 있습니다.
객체 리터럴 사용 이름:
var obj = {
key1: "it",
key2: function(){return obj.key1 + " works!"}
};
- 함수 내의 객체를 참조하기 위해 명시적으로 객체 리터럴 이름(예: obj)을 사용하면 함수가 항상 객체에 액세스할 수 있습니다.
- 그러나 이 접근 방식은 실수로 개체를 수정하거나 덮어쓸 수 있습니다. 객체에 대한 또 다른 참조가 생성되고 다른 값이 할당되면 함수는 원래 객체를 계속 참조합니다.
잠재적 문제:
-
사용 방법: 객체에서 함수를 추출할 때 전역 객체(브라우저의 창)를 참조할 수 있습니다.
-
객체 리터럴 이름 사용: 객체가 재할당되거나 수정될 때 함수는 업데이트된 객체 대신 원래 객체를 참조할 수 있습니다. 하나.
권장 사항:
-
사용 목적에 따라 접근 방식을 선택하세요. 기능이 주로 다음과 같은 경우에 사용하세요. 객체의 메소드로 사용됩니다. 함수를 추출하여 재사용할 가능성이 있는 경우 객체 리터럴 이름을 사용하세요.
-
ES6 const 또는 클로저 사용: ES6에서는 객체가 재할당되는 것을 방지하려면 const를 사용하세요. ES5에서는 클로저를 사용하여 로컬 범위를 생성하고 객체를 저장합니다.
-
함수를 객체에 바인딩합니다. obj.key2 = obj.key2.bind(obj)를 사용하여 다음을 보장합니다. 함수는 항상 올바른 객체를 참조합니다.
위 내용은 JavaScript 개체 리터럴의 자체 함수 내에서 개체 키를 가장 잘 참조하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!