JavaScript-이 구덩이 탈출 안내
4482 단어 es6Javascript
//nodejs
console.log(this); // {}
//
console.log(this); // windows
역할:현재 대상 을 동적 으로 지정 하고 현재 대상 을 사용 하 는 방법 은 this 를 어떻게 사용 합 니까?js 의 대상 이나 방법 이 this 역할 영역 을 가지 고 있다 면 this 는 어떤 구덩이 가 있 습 니까?*8195:js 원래 의 특성 으로 인해 this 의 역할 도 메 인 은 실행 할 때 확 정 됩 니 다.그러면 this 지향 이 명확 하지 않 습 니 다.구 덩이 를 보 세 요.
var name="global";
var test={
name:"test",
showName:function(){
console.log(this.name)
},
showArrow:function(){
setInterval(() => {console.log(this.name)}, 1000);
},
showFun:function(){
setInterval(function(){console.log(this.name)}, 1000);
}
}
test.showFun(); // undefined
test.showArrow(); // test
왜 undefined 를 출력 합 니까? 익명 함수 에 name 이 지정 되 어 있 지 않 기 때문에 undefined 솔 루 션 입 니 다.첫째,es6 에서 화살표 함수 화살표 함수 에서 this:정 의 를 내 릴 때 확 정 된 실질 입 니 다.화살표 함수 에 this 가 전혀 없습니다.외층 함수 의 this 만 참조 합 니 다.즉,this 지향 이 명확 하지 않 은 것 을 방지 하기 위해 자주 사용 하 는 this 할당:varself=this; 화살표 함 수 는 내부 에서 이 전략 을 사용 한 것 과 같 으 며,외부 역할 영역 을 참조 한 것 과 같 습 니 다.
var bird={
name:'bird',
speak:()=>{
//console.log(this);
console.log("I am a "+this.name);
}
}
var duck={
name:"duck",
speak:function(){
console.log("I am a "+this.name);
}
}
const type=(animal)=>{
if(typeof animal.speak == "function"){
animal.speak();
return true;
}
return false;
}
type(bird);
type(duck);
출력 결 과 는:
I am a undefined
I am a duck
왜 일 까요? 화살표 함수 내부 에 this 가 없 기 때문에 위로 this 를 찾 습 니 다.speak 는 함수 입 니 다.this 가 있 지만 this.name 은 할당 이 없 기 때문에 undefined 입 니 다.즉,8195,8195,8195.
화살표 함수 내부 에 this 가 없 기 때문에 화살표 함수 내부 에 인쇄 합 니 다.
{}
대상 2.bid 를 사용 하여 this 역할 대상 을 명시 적 으로 지정 합 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JavaScript로 카드 놀이를 넘기는 애니메이션을 만들려고했습니다.카드를 넘기는 애니메이션을 만들어 보았습니다. 폴더 구성은 다음과 같습니다. 코드는 다음과 같습니다. card_turning.html 다음은 JavaScript 코드입니다. cardTurning.js 결과는, 이런 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.