`this`와 JavaScript의 직접 객체 참조: 중첩 함수에 대해 어떤 접근 방식이 더 안전한가요?
자체 키 함수의 객체 리터럴 참조: 의미 평가
JavaScript에서는 객체 리터럴 내에 함수를 포함하는 것이 일반적입니다. 데이터와 동작을 캡슐화하는 방법. 그러나 이러한 함수 내에서 개체 속성에 액세스할 때 난관이 발생합니다. 이것을 사용해야 할까요, 아니면 개체 리터럴을 직접 참조해야 할까요?
이것을 사용하는 것과 직접 개체 참조를 사용하는 것
The 문제 설명에 제공된 첫 번째 예는 이것을 사용하여 객체 리터럴을 참조합니다.
var obj = { key1: "it", key2: function(){return this.key1 + " works!"} }; alert(obj.key2());
로그인 후 복사
그러나 두 번째 예는 이를 우회하고 객체를 직접 참조합니다.
var obj = { key1: "it", key2: function(){return obj.key1 + " works!"} }; alert(obj.key2());
로그인 후 복사
두 접근 방식의 잠재적인 함정
두 접근 방식 모두 문제를 일으킬 수 있습니다.
- 이 참조: 객체의 메소드로 호출되지 않는 경우 (obj.key2()), 이는 전역 객체와 같은 다른 것을 참조할 수 있습니다.
- 직접 객체 참조: 함수가 실행되는 동안 객체가 재할당되면 함수는 잘못된 값에 액세스할 수 있습니다.
함정
이러한 함정을 피하려면 다음과 같은 몇 가지 옵션이 있습니다.
- ES6 Const: 객체 재할당을 방지하려면 const를 사용하세요.
- 클로저: 객체를 로컬 범위에 저장합니다. 클로저.
- bind(): 함수를 객체에 바인딩하여 항상 올바른 객체를 참조하도록 합니다.
안전한 구현
다음 코드는 클로저를 사용한 안전한 구현을 보여줍니다.
var obj = (function(){ var local = { key1: "it", key2: function(){ return local.key1 + " works always!" } }; return local; })();
로그인 후 복사
위 내용은 `this`와 JavaScript의 직접 객체 참조: 중첩 함수에 대해 어떤 접근 방식이 더 안전한가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
Repo : 팀원을 부활시키는 방법
4 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD
R.E.P.O. 파일 저장 위치 : 어디에 있고 그것을 보호하는 방법은 무엇입니까?
3 몇 주 전
By DDD

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7315
9


자바 튜토리얼
1625
14


Cakephp 튜토리얼
1348
46


라라벨 튜토리얼
1261
25


PHP 튜토리얼
1208
29

