>웹 프론트엔드 >JS 튜토리얼 >javascript_basic 지식 중 일반적인 프로그래밍 지식

javascript_basic 지식 중 일반적인 프로그래밍 지식

WBOY
WBOY원래의
2016-05-16 17:37:551044검색

1.null 및 정의되지 않음

* 객체에서 속성을 얻습니다. 객체나 해당 프로토타입 체인의 객체 모두 속성이 없으면 속성 값이 정의되지 않습니다.
* 함수가 return을 통해 호출자에게 명시적으로 값을 반환하지 않는 경우 반환 값은 정의되지 않습니다. new를 사용하는 경우에는 특별한 경우가 있습니다.
* JavaScript의 함수는 형식 매개변수를 얼마든지 선언할 수 있습니다. 함수가 실제로 호출될 때 전달된 매개변수 수가 선언된 형식 매개변수보다 적으면 추가 형식 매개변수의 값이 정의되지 않습니다.
* null은 빈 객체입니다. 빈 객체({})와의 차이점에 주의하세요.
간단히 말하면 모든 변수에 대해 선언 후 초기값이 지정되지 않은 한 정의되지 않은 상태가 되며 null 참조 개념을 표현하기 위해 Object 유형을 사용하는 경우에는 null로 표시됩니다. .

2.if 표현식

* Null은 항상 false(false)
* Undefine은 항상 false(false)
* 숫자 0, -0 또는 NaN은 false, 다른 값은 true
* 문자열 문자열일 때 비어 있으면 false이고 다른 값은 true
* 객체는 항상 true(true)

3.배열

JavaScript의 배열은 Java나 C/C와 같은 일반적인 프로그래밍 언어의 배열과 매우 다릅니다. JavaScript의 객체는 순서가 지정되지 않은 연관 배열이며 Array는 JavaScript의 객체 기능을 활용하여 구현됩니다. JavaScript에서 Array는 실제로 객체이지만 해당 속성 이름은 정수입니다. 배열을 편리하게 조작하기 위한 추가 속성(예: 길이)과 메서드(예: splice)가 있습니다.

4.신규 연산자

자바스크립트는 자바에서 클래스라는 개념이 없지만 생성자를 사용하여 객체를 생성합니다. 새 표현식의 생성자를 사용하여 새 개체를 만들 수 있습니다. 생성자에 의해 생성된 객체에는 생성자의 프로토타입에 대한 암시적 참조가 있습니다.


5.프로토타입

프로토타입은 자바스크립트 프로토타입 상속의 핵심 개념입니다. 특정 자바스크립트 클래스 라이브러리에서 Array.prototype.push.call()의 사용법을 보셨을 것이므로 최종 분석에서는 프로토타입이 객체입니다. 프로토타입을 통해 네이티브 클래스에 몇 가지 유용한 메서드를 추가할 수 있고 프로토타입을 통해 상속을 구현할 수도 있습니다. 프로토타입에 더 관심이 있다면 ff의 __proto__를 통해 지정된 객체의 프로토타입 체인에 접근할 수 있습니다.

6.스코프 체인

실행 컨텍스트는 JavaScript 코드 실행을 설명하기 위해 ECMAScript 사양에서 사용되는 추상 개념입니다. 모든 JavaScript 코드는 실행 컨텍스트 내에서 실행됩니다. 현재 실행 컨텍스트에서 함수가 호출되면 새 실행 컨텍스트가 입력됩니다. 함수 호출이 끝나면 원래 실행 컨텍스트로 돌아갑니다. 함수 호출 중에 예외가 발생하고 포착되지 않으면 여러 실행 컨텍스트에서 종료될 수 있습니다. 함수 호출 프로세스 중에 다른 함수를 호출하여 새로운 실행 컨텍스트를 시작할 수도 있습니다. 이는 실행 컨텍스트 스택을 형성합니다.

참고: 범위 체인에 더 관심이 있는 경우 ff의 __parent__ 속성을 통해 함수의 범위 체인에 액세스할 수 있습니다. 불행하게도 ff의 js 엔진 SpiderMonkey는 이 속성을 완벽하게 지원하지 않으며 내부 함수가 나타납니다. 오류가 발생하므로 Rhino(http://developer.mozilla.org/en/docs/Rhino) 사용을 권장합니다.

참고: 여기서 언급해야 할 것은 함수 표현식과 함수 선언이 범위 체인에 미치는 영향입니다.

7.폐쇄

클로저는 js에서도 흔히 사용되는 기능입니다. 일반적으로 Java에서 함수를 실행하면 모든 내부 변수가 재활용됩니다. 그러나 Javascript에서는 특정 메소드를 사용하여 실행된 함수가 여전히 존재하도록 할 수 있습니다. 접근 가능하여 클로저를 형성합니다.

물론 모든 것에는 양면이 있습니다. 클로저에는 이점이 있지만, 주의하지 않으면 메모리 누수 등 많은 문제가 발생할 수도 있으므로 이러한 기술을 합리적으로 적용해야 합니다. 클로저에 대해 자세히 알아보고 싶다면 여러 js 라이브러리(prototype, jquery, mootools)를 확인하는 것이 좋습니다. 여기에는 바인드 메서드 등과 같은 매우 고전적인 클로저 애플리케이션이 포함되어 있습니다. 자세한 내용은 다루지 않겠습니다. 여기.

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