Javascript 객체 리터럴의 "this" 키워드 동작
객체 리터럴 내에서 "this" 키워드는 객체에 대한 자리 표시자 역할을 합니다. 그 자체. 그러나 해당 동작은 호출되는 조건에 따라 달라질 수 있습니다.
코드에서:
var MyDate = function(date) { this.date = date; }; var obj1 = { foo: new Date(), bar: new MyDate(this.foo) // this.foo is undefined }; var obj2 = {}; obj2.foo = new Date(); obj2.bar = new MyDate(this.foo); // this.foo is undefined var obj3 = { foo: new Date(), bar: new MyDate(obj3.foo) }; var obj4 = {}; obj4.foo = new Date(); obj4.bar = new MyDate(obj4.foo);
"this" 바인딩 이해
Javascript의 "this" 키워드는 지연 바인딩을 나타냅니다. 즉, 해당 값은 함수가 호출될 때까지 결정되지 않습니다. 귀하의 경우:
시나리오 1 및 2:
시나리오 3 및 4:
결론
객체 내에서 "this" 키워드의 동작 리터럴은 함수가 호출되는 컨텍스트에 따라 달라집니다. 객체에 명시적으로 바인딩되지 않은 경우 기본값은 전역 객체입니다. 그러나 객체의 메소드로 호출되면 해당 특정 객체를 참조하여 객체의 속성과 메소드에 대한 적절한 액세스를 보장합니다.
위 내용은 JavaScript 객체 리터럴에서 `this` 키워드는 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!