이에 대한 설명을 Javascript로
Javascript의 this은
초심자 javascript가 js에 대해 많은 혼란을 겪게 될 것임을 가리킵니다. 다음 예 : var
a = 'jack';var obj = {a: ,b : function (){ 콘솔.log(this.a) ;}} ;var c = obj .b;c();//outputjackjs을 처음 접하는 사람들은 이해할 수 있습니다 ,
일부에서는 다른 객체 지향 언어여기 출력은 tom,이어야 한다고 생각합니다. 하지만 실제로 여기 출력은 jack , 근데 이게 무엇을 요구하는 걸까요?그리고 포스터가 단계별로 분석할 것입니다. step. js를 가리키는 일반적인 this
는 4 유형:1으로 나뉩니다. 객체
객체에 있는 내용this , 즉, 객체의 속성은 function, 이고
function에는 this, 의 사용이 포함됩니다. 예를 들어 다음 예는 다음과 같습니다. : var obj = {a: 'tom',b: function(){ 콘솔.log( this.a);}};obj.b(); //출력은 입니다. tom 이 경우 this는 함수를 호출하는 개체를 가리킵니다. 여기는 obj입니다. 또 다른 예는 다음과 같습니다: var obj = {a: 'tom',b: function(){ console.log (이 . a);},c: {c0: '장미',c1 : 기능 () { 콘솔.log(this.c0);} } };obj.c .c1();//outputjack 함수 가 호출되면 에는 여러 개체가 포함됩니다. 이 함수는 가장 바깥쪽 개체에 의해 호출되지만 this는 해당 상위 개체 ? var a = 'jack';var obj = {a : '톰 ', b: function(){(this. a); } };var c = obj.b;c();//outputjack 모두들 한 가지씩 this 라고 마지막으로 호출한 개체를 가리킵니다. 는 여기의 c 값도 obj.b, 에 할당되어 있지만 변수 c는 여전히 전역 window 개체 , 에 걸려 있으므로 결국 this은 전역 window 개체 2를 가리킵니다. 직접전화하세요 함수 var name = 'tom';var a = function(){ var 이름 = ' jack';console.log(this.name);};console.log (a( ; ow.a()그래서 this는 전역 window 를 가리킵니다. 에는 이 경우가 포함됩니다. :var 이름 = '톰 ' ;var a = function var name = 'jack' ;기능 b ㅋㅋㅋ ) //출력톰 ㅋㅋㅋ 아 ()) ; //출력tom a 및 b는 모두 tom을 출력하고, 함수 b 는 함수에서 이후에 호출될 때 여전히 전역 windowobject를 가리킵니다. , 왜 이것이 한 문장을 기억할 수 있습니다. js에 함수를 직접 호출하는 개체가 없으면 함수가 호출될 때 this의 포인터가 됩니다. 은 window 객체 를 가리킬 것입니다. , obect.function()을 호출할 때 이전 예제와 같습니다. this 에서 object을 가리킬 것입니다. 좋아요 var obj = {a: 'tom',b: function (){ 콘솔. log (this.a);}};obj.b() ; //출력 tom 첫 번째 예와 마찬가지로 이 문장으로 이해하기 쉽습니다 , 함수 c 호출에는 개체 호출이 없으므로 전역 창문 개체 var a = 'jack';var obj = {a: 'tom', b: function(){ console.log(this.a); } };var c = obj.b;c();//outputjack Js 에서는 생성자와 일반 함수 사이에 명확한 구분이 없습니다. 일반 함수를 사용하여 객체 유형을 생성하는 경우 이를 생성자 또는 생성자라고 합니다. 함수가 실제 생성자로 작동하려면 다음 조건을 충족해야 합니다: 1 일반적으로 속성과 메서드를 추가하여 함수 내에서 새 객체(this)의 속성을 설정합니다. 2, 생성자는 반환 문을 포함할 수 있지만(권장되지 않음) 반환 값은 this 또는 기타 비객체 유형 값이어야 합니다. 예를 들어: 기능 People(name, age, sex){this.name = 이름;this p = new People ('tom',12,'남성 '); console.log (p.name + p.sex + p.age); //Outputtom 남자12 여기 this는 현재 생성된 객체를 가리킵니다. 물론 생성자에도 특별한 경우가 있습니다, 예를 들어: 기능 People(name, age, sex){this.name = 이름;this ㅋㅋㅋ ;}var p = new People('tom',12,'남성 ' );콘솔. log(p.name);//outputundefine여기서 생성자의 반환 값이 this 또는 객체가 아닌 유형 , 여기서 People은 엄밀한 의미에서 생성자가 아닙니다, 여기에 선언된 p은 실제로 함수 People의 반환 값일 뿐입니다. , 그래서 최종 출력은 여기서 반환된 값을 객체가 아닌 유형으로 변경하면 최종 결과는 달라집니다 기능 People(name, age, sex){this.name = 이름;this ㅋㅋㅋ p = 새 People('tom',12,'male');콘솔 로그(p. name);//outputtom엄밀한 의미에서 People은 생성자입니다, So thisstill 현재 생성된 것을 가리킨다. 개체 Call과 apply 함수는 거의 같습니다, 첫 번째 매개변수는 호출 함수의 개체입니다 , 뒤에 의 매개변수는 모두 함수 매개변수입니다, 는 단지 call입니다. 함수의 매개변수 전달 방법은 무제한의 매개변수 , , 즉 call([ thisObject[,arg1 [,arg2 [ ,...,argn]]]]) 뒤의 매개변수는 각각 함수 호출의 매개변수 , 에 해당하며 apply 함수의 첫 번째 매개변수는 call과 동일, 두 번째 매개변수는 배열 유형입니다, apply([thisObj [,argArray] ])배열의 각 요소는 함수 호출의 매개변수에도 해당합니다. , call 또는 apply를 사용하는 경우 함수는 이며, 메서드의 this은 call의 첫 번째 매개 변수로 리디렉션됩니다. 또는 신청하세요 기능 , 예를 들어: var a = 1;var b = 2;var c = {a: 3 ,b: 4};function add(){ console.log( 이. a + this.b)}add();//output3add .신청(c );//Output7 첫 번째 add 호출에는 개체에 대한 직접 호출이 없으므로 전역 window 개체를 가리킵니다. 출력 결과는 3입니다. 첫 번째 add 함수는 apply 함수를 통해 호출되므로 this의 포인터는 c 로 향하게 됩니다. 최종 출력 결과는 7 Es6Expansion: this Es6에 있는 화살표 함수의 this 포인터는 es5의 this과 다릅니다. 여기서 언급하겠습니다: 제본 this, 이는 자신이 있는 컨텍스트(즉, 정의된 위치)의 this 값을 자체 this 값으로 캡처하므로 call() / apply() / 바인딩() 메소드는 화살표 함수에 매개변수만 전달하며 해당 this 에는 영향을 미치지 않습니다. this 이 어휘 수준에 있다는 점을 고려하면 엄격 모드에서 과 관련된 규칙은 무시됩니다. 1 objectvar a = {name: 'tom',b: { c: ( ) => };a.b , so 객체에서 화살표 기능을 사용할 때 this의 포인터도 전역 창을 가리킵니다. object.2. 메소드에서 화살표 함수 호출 var test = function(){this.시간 = 1 ;setTimeout(()= > 00)}; var t = new test();// 출력 1 거기 this는 화살표 함수의 pointer, so 포인팅은 생성된 컨텍스트에만 관련됩니다. , 여기에 생성자의 호출이 있으므로 this를 포인팅합니다. test의 는 t , 따라서 화살표 함수의 this도 반환 개체 를 가리킵니다. 에 대한 더 많은 관련 내용을 보려면 PHP 중국어 웹사이트를 주목하세요. 관련 추천: Word, txt, Excel, PPT 및 기타 파일을 업로드하는 WeChat 미니 프로그램에 대한 자세한 설명 백엔드 PHP를 통해 WeChat 미니 프로그램을 통해 파일을 다운로드하는 방법 MySQL 성능 향상을 위한 7가지 팁 소개, 글로벌 세계에서 함수를 직접 호출
3. 생성자에 있는 this
의 포인터입니다. 4. call 또는 applyCall 함수
위 내용은 이에 대한 설명을 Javascript로의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript는 웹 개발에 널리 사용되는 프로그래밍 언어인 반면 WebSocket은 실시간 통신에 사용되는 네트워크 프로토콜입니다. 두 가지의 강력한 기능을 결합하면 효율적인 실시간 영상 처리 시스템을 만들 수 있습니다. 이 기사에서는 JavaScript와 WebSocket을 사용하여 이 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 첫째, 실시간 영상처리 시스템의 요구사항과 목표를 명확히 할 필요가 있다. 실시간 이미지 데이터를 수집할 수 있는 카메라 장치가 있다고 가정해 보겠습니다.
