웹 프론트엔드 JS 튜토리얼 JavaScript 범위 및 이 키워드

JavaScript 범위 및 이 키워드

Nov 28, 2016 pm 02:14 PM

프로그래머로서 여러분은 C++의 this 또는 Python의 self와 같이 객체 지향 언어에서 현재 객체를 참조하는 참조(또는 포인터)에 익숙했을 것입니다. 물론 OO 속성도 있습니다(javascript는 실제로 소위 함수형 언어인 JavaScript에도 현재 속성의 객체를 참조하는 포인터(또는 참조)가 있는데, 이것이 바로 this 키워드입니다.

이 키워드를 이해하려면 한 문장만 기억하고 싶다면 이 키워드가 항상 현재 함수의 소유자 객체(실행 공간)를 가리키는 것이 되어야 합니다. , 아래의 자세한 지침을 참조하세요.

그럼 범위란 무엇인가요?

위키피디아의 설명은 다음과 같습니다. 컴퓨터 프로그래밍에서 범위는 값과 표현이 연관된 둘러싸는 컨텍스트입니다. 중국어는 값이나 표현식과 연관된 컨텍스트(참조할 수 있는 실행 공간)를 지정하는 소위 범위입니다.

이것과 범위가 무슨 관련이 있나요? 위의 정의에서 this는 항상 현재 이 함수를 참조하는 개체를 가리키며, 현재 참조되는 개체를 확인하려면 현재 함수의 범위를 파악해야 합니다. 자세한 내용은 아래 분석을 참조하세요.

이 키워드

아래의 몇 가지 예를 참조하세요.

파이썬 예:

class Person(object):
"""a person class
    """
def __init__(self, name):
self.name = name    #这里的self指向的是实例化后的对象,如下面中的Magic
def get_name(self):
return self.name
Magic = Person("Magic")
print Magic.name
로그인 후 복사

자바스크립트 예:

window.name = "Magic from window"
var get_name = function(){
    // this的具体指向只能在运行时才能确定,也就是确定运行时调用其的对象
    return this.name;   
};
// 输出Magic from window, get_name调用的对象为window
alert(get_name());  
var obj = {}
obj.name = "Magic from obj";
// 输出Magic from obj, 我们强制地使用了 apply来更改调用的对象,使其指向obj
alert(get_name.apply(obj)); 
var innerobj = {
    "name" : "Magic from innerobj"
};
innerobj.get_name = get_name;   // 使得innerobj的get_name方法指向了global scope的get_name函数
alert(innerobj.get_name()); // 输出Magic from innerobj, 此时this指向的是innerobj
로그인 후 복사

위의 간단한 예에서 이는 항상 런타임에 실행될 수 있습니다. 특정 방향을 호출 개체를 알 수 있습니까? 그리고 이는 동적 언어의 중요한 특징이기도 합니다.

그럼 이것이 현재 가리키는 참조 객체를 어떻게 결정할까요? 일반적으로 다음과 같이 판단할 수 있습니다.

전역 범위에서 호출되는 경우(전역 범위가 무엇인지 명확히 하려면 아래 설명 참조) Bowser의 최상위 개체 창을 가리킵니다. : get_name()

이런 참조가 있다면 innerobj. get_name(), 이것이 innerobj

을 가리키는 것이 분명합니다. Apply 또는 call을 사용하여 강제 참조 개체를 가리키면 get_name과 같은 강제 개체도 가리킬 것입니다. 적용(obj).

적용 및 호출에 대하여

이 두 키워드는 이 참조 객체(실행 공간)의 강제로 쉽게 이해될 수 있습니다. 두 키워드의 구문은 다음과 같습니다.

fun. .call(object, arg1, arg2, ...)

fun.apply(object, [arg1, arg2, ...])

둘의 목적은 동일합니다(동적) 함수의 실행 공간을 바꾸거나, 이것이 가리키는 객체를 바꾸거나), 함수에 제공되는 매개변수의 호출 방식만 다릅니다.

샘플 코드는 다음과 같습니다.

var test_call_apply = function(name, gender, school){
alert(this.age + name + gender + school);
};
test_call_apply.call({age:24}, "Magic", "male", "ISCAS");
test_call_apply.apply({age:24}, ["Magic", "male", "ISCAS"]);
로그인 후 복사

범위 세부 정보

var global_scope = "I'm global";
var fun = function(){
var fun_scope = "I'm in fun scope";
return innerfun(){
var inner_func_scope = "I'm in the inner fun scope";
return global_scope + fun_scope + inner_func_scope; //此处的引用是重要的,请特别注意
};
};
alert(fun()());
로그인 후 복사

위 코드에 유의하세요. 여기서:

global_scope는 전역 범위입니다.

fun_scope는 함수의 범위입니다.

inner_func_scope 함수 내에 위치한 함수의 범위입니다

계속해서 함수를 삽입할 수도 있으며 그러면 여러 범위가 생성됩니다.

그러면 왜 innerfun 메소드가 자신의 범위에 속하지 않는 변수를 참조할 수 있는가 하는 질문이 생깁니다.

이 질문에 답하기 전에 먼저 스코프 체인의 개념을 소개해야 합니다. 소위 범위 체인은 JavaScript 코드에 형성된 우선순위 및 관련 범위의 체인을 나타냅니다.

위 코드를 예로 들면

전역 범위의 경우 자체적으로 전역 범위 체인을 생성합니다(물론 현재 이 체인에는 범위가 하나만 있습니다).

fun 함수의 범위를 위해 먼저 전역과 동일한 범위 체인을 설정한 다음 다음 구조와 유사하게 자체 범위(현재 이 체인에는 2개의 범위가 있음)를 추가합니다. global ==>fun

innerfun의 경우 fun 함수가 소유한 체인 외에도 자체 범위도 추가합니다(물론 현재 이 체인에는 3개의 범위가 있습니다). 구조 : global==>fun==>innerfun

스코프 체인은 다음과 같은 특징을 갖습니다:

순서 지정

함수가 생성될 때마다 범위와 추가 자신만의 스코프 체인에 추가하세요

이 체인은 스택과 비슷합니다. 변수를 찾을 때는 항상 위에서부터 시작하세요.


실제로는 표현식을 계산할 때 자체 스코프 체인을 위에서 아래로 검색하고, 검색한 후 전체 체인을 찾지 못하면 즉시 이 값을 반환한다는 것을 이해하기 쉽습니다.

이 검색 메커니즘은 일반적으로 체인의 프런트 엔드에 위치한 범위가 더 높은 우선 순위를 갖는다고 결정합니다.

예를 들어 javascript가 global_scope + fun_scope + inner_func_scope; 표현식을 계산할 때 위 이미지의 범위 체인을 찾아 최종 결과를 결정합니다.

一些说明

如果你弄清楚了上面的论述,应该说你对this关键字和scope已经具有完全的知识基础了,但是我们需要在实际中更好地使用和理解这些概念,这样才能把能力上升到别一个层次,这也即所谓的理论与实践的关系。

请看下面这个例子:

var change_color = function(){
this.style.color = "red";
};
window.onload = function(){
var text = document.getElementById("text");
text.onclick = change_color;    //此时this指向的是text这个对象(dom对象)
};
// 下面这行代码是在body中
//这点需要特别注意, inline script指向的是window,此处会无定义  
<span id="another" onclick="change_color()">My color will be changed2.</span>
로그인 후 복사

需要特别注意的是:

inline event registration中的this并非指向的是自己的dom节点,而是global scope的window,这点可以从上面的例子中得到证明

这种inline event registration是不可取的,推荐的是 Unobtrusive JavaScript (处理逻辑和页面结构相分离)

javascript 是一种非常强大的动态语言,它是披着C语言外衣的函数式语言,如果你只当作它是一种类C的命令式语言,那么你的知识层次还过于低,而倘若你能够理解到javascript 的函数式语言本质,你在运用 javascript,理解 jQuery 及其它的库,甚至自己写一些 javascript 都会游刃有余的。


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? 프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? Apr 04, 2025 pm 02:42 PM

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

Demystifying JavaScript : 그것이하는 일과 중요한 이유 Demystifying JavaScript : 그것이하는 일과 중요한 이유 Apr 09, 2025 am 12:07 AM

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? Apr 04, 2025 pm 05:09 PM

동일한 ID로 배열 요소를 JavaScript의 하나의 객체로 병합하는 방법은 무엇입니까? 데이터를 처리 할 때 종종 동일한 ID를 가질 필요가 있습니다 ...

JavaScript는 배우기가 어렵습니까? JavaScript는 배우기가 어렵습니까? Apr 03, 2025 am 12:20 AM

JavaScript를 배우는 것은 어렵지 않지만 어려운 일입니다. 1) 변수, 데이터 유형, 기능 등과 같은 기본 개념을 이해합니다. 2) 마스터 비동기 프로그래밍 및 이벤트 루프를 통해이를 구현하십시오. 3) DOM 운영을 사용하고 비동기 요청을 처리합니다. 4) 일반적인 실수를 피하고 디버깅 기술을 사용하십시오. 5) 성능을 최적화하고 모범 사례를 따르십시오.

Shiseido의 공식 웹 사이트와 같은 시차 스크롤 및 요소 애니메이션 효과를 달성하는 방법은 무엇입니까?
또는:
Shiseido의 공식 웹 사이트와 같은 페이지 스크롤과 함께 애니메이션 효과를 어떻게 달성 할 수 있습니까? Shiseido의 공식 웹 사이트와 같은 시차 스크롤 및 요소 애니메이션 효과를 달성하는 방법은 무엇입니까? 또는: Shiseido의 공식 웹 사이트와 같은 페이지 스크롤과 함께 애니메이션 효과를 어떻게 달성 할 수 있습니까? Apr 04, 2025 pm 05:36 PM

이 기사에서 시차 스크롤 및 요소 애니메이션 효과 실현에 대한 토론은 Shiseido 공식 웹 사이트 (https://www.shiseido.co.jp/sb/wonderland/)와 유사하게 달성하는 방법을 살펴볼 것입니다.

JavaScript의 진화 : 현재 동향과 미래 전망 JavaScript의 진화 : 현재 동향과 미래 전망 Apr 10, 2025 am 09:33 AM

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

Console.log 출력 결과의 차이 : 두 통화가 다른 이유는 무엇입니까? Console.log 출력 결과의 차이 : 두 통화가 다른 이유는 무엇입니까? Apr 04, 2025 pm 05:12 PM

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...

See all articles