JS_javascript 기술에 객체가 존재하는지 확인하는 10가지 방법 요약
Javascript 언어의 디자인은 충분히 엄격하지 않으며 주의하지 않으면 여러 곳에서 오류가 발생할 수 있습니다.
예를 들어, 다음과 같은 상황을 생각해 보세요.
이제 전역 개체 myObj가 존재하는지 확인해야 합니다. 존재하지 않으면 선언하세요. 자연어로 기술한 알고리즘은
if (myObj가 존재하지 않음){
myObj를 선언하세요.
}
이 코드를 작성하는 것이 쉽다고 생각할 수도 있습니다. 그러나 실제로 관련된 문법적 문제는 우리가 상상하는 것보다 훨씬 더 복잡합니다. Juriy Zaytsev는 Javascript 객체가 존재하는지 확인하는 방법이 50가지 이상 있다고 지적했습니다. Javascript 언어의 구현 세부 사항에 대해 매우 명확한 경우에만 둘 사이의 차이점을 알 수 있습니다.
첫 번째 작성 방법
직관에 따라 다음과 같이 작성할 수 있다고 생각할 수도 있습니다.
if (!myObj) {
myObj = { };
그러나 실행 이 코드의 경우 브라우저에서 직접 ReferenceError 오류가 발생하여 작업이 중단됩니다. 무슨 일이야?
그런데 if 문에서 myObj가 비어 있는지 확인하면 이 변수가 아직 존재하지 않으므로 오류가 보고됩니다. 다음과 같이 변경하면 정상적으로 실행됩니다.
}
var를 추가했는데 왜 오류가 없나요? 이 경우 if 문이 판단을 내릴 때 myObj가 이미 존재하는 것이 아닐까요?
이 질문에 대답하려면 Javascript 인터프리터가 어떻게 작동하는지 알아야 합니다. Javascript 언어는 "먼저 구문 분석한 후 실행"입니다. 구문 분석 중에 변수 선언이 완료되었으므로 위 코드는 실제로
var myObj = { };
따라서 if 문이 판단할 때 myObj가 이미 존재하므로 오류가 보고되지 않습니다. 이는 var 명령의 "코드 호이스팅" 효과입니다. Javascript 인터프리터는 var 명령으로 정의된 변수만 "승격"하고 var 명령을 사용하지 않고 직접 할당된 변수에서는 작동하지 않습니다. 이것이 var가 추가되지 않으면 오류가 보고되는 이유입니다.
두 번째 작성 방법
var 명령 외에도 다시 작성하여 올바른 결과를 얻는 또 다른 방법이 있습니다.
코드 복사
코드는 다음과 같습니다.
Window는 JavaScript의 최상위 객체이며 모든 전역 변수는 속성입니다. 따라서 myobj가 비어 있는지 확인하는 것은 창 개체에 myobj 특성이 있는지 확인하는 것과 동일하므로 myObj가 정의되지 않아 발생하는 ReferenceError 오류를 피할 수 있습니다. 하지만 코드의 표준화 측면에서 두 번째 줄에 var를 추가하는 것이 가장 좋습니다.
코드 복사
코드는 다음과 같습니다. 다음과 같습니다:
if (!window.myObj) {
window.myObj = { }
}
세 번째 작성 방법
위 작성 방법의 단점은 일부 실행 환경(V8, Rhino 등)에서는 window가 최상위 개체가 아닐 수 있다는 것입니다. 따라서 다음과 같이 다시 작성해 보세요.
코드 복사
코드는 다음과 같습니다.
전역 변수 수준에서 this 키워드는 항상 최상위 변수를 가리키므로 다양한 운영 환경에 독립적일 수 있습니다.
네 번째 작성 방법
그러나 위의 작성 방법은 가독성이 떨어지고 this의 포인터가 가변적이고 오류가 발생하기 쉬우므로 추가로 다시 작성합니다.
var global = this; > if (!global.myObj) {
global.myObj = { };
}
사용자 정의 변수 global을 사용하는 것이 훨씬 더 명확합니다. 최상위 객체.
다섯 번째 작성 방법
typeof 연산자를 사용하여 myObj가 정의되었는지 확인할 수도 있습니다.
var myObj = {};
}
현재 자바스크립트 객체가 존재하는지 확인하는 데 가장 널리 사용되는 방법입니다.
6번째 작성 방법
myObj의 값은 정의되었으나 할당되지 않은 경우 정의되지 않은 값과 동일하므로 위의 작성 방법을 단순화할 수 있습니다.
var myObj = { };
}
여기서 주목해야 할 두 가지 사항이 있습니다. 첫째, 두 번째 줄의 var 키워드는 누락될 수 없습니다. 그렇지 않으면 ReferenceError 오류가 발생합니다. , undefed는 작은따옴표나 큰따옴표와 함께 추가할 수 없습니다. 왜냐하면 여기서 비교되는 것은 문자열 "undefine"이 아니라 undefed 데이터 유형이기 때문입니다.
7번째 글쓰기 방법
위의 쓰기 방식은 "정확한 비교"(===)의 경우에도 여전히 유효합니다.
var myObj = { } ;
}
자바스크립트의 언어 설계에 따르면 undefine == null이므로 myObj가 같은지 비교합니다. null로 변환하면 올바른 결과를 얻을 수도 있습니다.
var myObj = { };
}
그러나 실행 결과는 정확하지만 의미상으로는 이 판단은 방법이 잘못되었으므로 피해야 합니다. null은 null 값이 할당된 빈 개체, 즉 이 개체가 실제로 값을 갖는 개체를 참조하고, undefined는 존재하지 않거나 값이 할당되지 않은 개체를 참조하기 때문입니다. 따라서 여기서는 "비교 연산자"(==)만 사용할 수 있습니다. 여기서 "정확한 비교 연산자"(===)를 사용하면 오류가 발생합니다.
아홉 번째 작성 방법
in 연산자를 사용하여 myObj가 최상위 개체의 속성인지 확인할 수도 있습니다.
window.myObj = { };
}
마지막으로 hasOwnProperty 메소드를 사용하여 myObj가 상위의 속성인지 확인합니다. -레벨 객체:
this.myObj = { };
}
1. 객체가 존재하는지 여부만 판단하는 경우 다섯 번째 작성 방법을 사용하는 것이 좋습니다. 2. 객체 존재 여부 외에도 객체에 null 값이 있는지 확인해야 하는 경우 첫 번째 작성 방법을 사용하는 것이 좋습니다.
3. 특별한 사정이 없는 한 모든 변수는 var 명령어를 사용하여 선언해야 합니다.
4. 크로스 플랫폼을 위해서는 최상위 객체를 표현하기 위해 창을 사용하지 않는 것이 좋습니다.
5. Javascript 언어에서는 null과 정의되지 않음이 혼동되기 쉽습니다. 둘 다 관련될 수 있는 경우 "정확한 비교" 연산자(===)를 사용하는 것이 좋습니다.

핫 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)

뜨거운 주제











JS 및 Baidu Map을 사용하여 지도 팬 기능을 구현하는 방법 Baidu Map은 지리 정보, 위치 지정 및 기타 기능을 표시하기 위해 웹 개발에 자주 사용되는 널리 사용되는 지도 서비스 플랫폼입니다. 이 글에서는 JS와 Baidu Map API를 사용하여 지도 이동 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 준비 바이두 맵 API를 사용하기 전에 먼저 바이두 맵 오픈 플랫폼(http://lbsyun.baidu.com/)에서 개발자 계정을 신청하고 애플리케이션을 만들어야 합니다. 생성 완료

주식 분석을 위한 필수 도구: PHP 및 JS에서 캔들 차트를 그리는 단계를 배우십시오. 인터넷과 기술의 급속한 발전으로 주식 거래는 많은 투자자에게 중요한 방법 중 하나가 되었습니다. 주식분석은 투자자의 의사결정에 있어 중요한 부분이며 캔들차트는 기술적 분석에 널리 사용됩니다. PHP와 JS를 사용하여 캔들 차트를 그리는 방법을 배우면 투자자가 더 나은 결정을 내리는 데 도움이 되는 보다 직관적인 정보를 얻을 수 있습니다. 캔들스틱 차트는 주가를 캔들스틱 형태로 표시하는 기술 차트입니다. 주가를 보여주네요

얼굴 검출 및 인식 기술은 이미 상대적으로 성숙하고 널리 사용되는 기술입니다. 현재 가장 널리 사용되는 인터넷 응용 언어는 JS입니다. 웹 프런트엔드에서 얼굴 감지 및 인식을 구현하는 것은 백엔드 얼굴 인식에 비해 장점과 단점이 있습니다. 장점에는 네트워크 상호 작용 및 실시간 인식이 줄어 사용자 대기 시간이 크게 단축되고 사용자 경험이 향상된다는 단점이 있습니다. 모델 크기에 따라 제한되고 정확도도 제한됩니다. js를 사용하여 웹에서 얼굴 인식을 구현하는 방법은 무엇입니까? 웹에서 얼굴 인식을 구현하려면 JavaScript, HTML, CSS, WebRTC 등 관련 프로그래밍 언어 및 기술에 익숙해야 합니다. 동시에 관련 컴퓨터 비전 및 인공지능 기술도 마스터해야 합니다. 웹 측면의 디자인으로 인해 주목할 가치가 있습니다.

PHP와 JS를 사용하여 주식 캔들 차트를 만드는 방법 주식 캔들 차트는 주식 시장에서 흔히 사용되는 기술 분석 그래픽으로 시가, 종가, 최고가 등의 데이터를 그려서 투자자가 주식을 보다 직관적으로 이해할 수 있도록 도와줍니다. 주식의 최저 가격. 이 기사에서는 특정 코드 예제와 함께 PHP 및 JS를 사용하여 주식 캔들 차트를 만드는 방법을 설명합니다. 1. 준비 시작하기 전에 다음 환경을 준비해야 합니다. 1. PHP를 실행하는 서버 2. HTML5 및 Canvas를 지원하는 브라우저 3

인터넷 금융의 급속한 발전으로 인해 주식 투자는 점점 더 많은 사람들의 선택이 되었습니다. 주식 거래에서 캔들 차트는 주가의 변화 추세를 보여주고 투자자가 보다 정확한 결정을 내리는 데 도움이 되는 일반적으로 사용되는 기술적 분석 방법입니다. 이 기사에서는 PHP와 JS의 개발 기술을 소개하고 독자가 주식 캔들 차트를 그리는 방법을 이해하도록 유도하며 구체적인 코드 예제를 제공합니다. 1. 주식 캔들 차트의 이해 주식 캔들 차트를 그리는 방법을 소개하기 전에 먼저 캔들 차트가 무엇인지부터 이해해야 합니다. 캔들스틱 차트는 일본인이 개발했습니다.

JS 및 Baidu Maps를 사용하여 지도 열 지도 기능을 구현하는 방법 소개: 인터넷과 모바일 장치의 급속한 발전으로 지도는 일반적인 응용 시나리오가 되었습니다. 시각적 표시 방법인 히트맵은 데이터 분포를 보다 직관적으로 이해하는 데 도움이 될 수 있습니다. 이 기사에서는 JS 및 Baidu Map API를 사용하여 지도 히트맵 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 준비 작업: 시작하기 전에 Baidu 개발자 계정, 애플리케이션 생성, 해당 AP 획득 등의 항목을 준비해야 합니다.

JS 및 Baidu Maps를 사용하여 지도 다각형 그리기 기능을 구현하는 방법 현대 웹 개발에서 지도 애플리케이션은 일반적인 기능 중 하나가 되었습니다. 지도에 다각형을 그리면 사용자가 보고 분석할 특정 영역을 표시하는 데 도움이 될 수 있습니다. 이 기사에서는 JS 및 Baidu Map API를 사용하여 지도 다각형 그리기 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 Baidu Map API를 도입해야 합니다. 다음 코드를 사용하여 Baidu Map API의 JavaScript를 HTML 파일로 가져올 수 있습니다.

JS 및 Baidu Maps를 사용하여 지도 클릭 이벤트 처리 기능을 구현하는 방법 개요: 웹 개발에서는 지리적 위치 및 지리적 정보를 표시하기 위해 지도 기능을 사용해야 하는 경우가 많습니다. 지도에서의 클릭 이벤트 처리는 지도 기능에서 일반적으로 사용되는 중요한 부분입니다. 이 글에서는 JS와 Baidu Map API를 사용하여 지도의 클릭 이벤트 처리 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 단계: Baidu Map API 파일 가져오기 먼저 다음 코드를 통해 Baidu Map API 파일을 가져올 수 있습니다.
