[javascript] 왜 null이 객체이고 null과 undefined의 차이점은 무엇입니까?

JavaScript에서 왜 null간주 object됩니까?

확인 중

if ( object == null )
      Do something

와 동일

if ( !object )
      Do something

?

그리고 또한:

차이점은 무엇이며 null그리고 undefined?



답변

(name is undefined)

당신 : 무엇입니까 name? (*)
JavaScript : name ? 무엇입니까 name? 당신이 무슨 말을하는지 모르겠습니다. 이전에 언급 한 적이 없습니다 name. (클라이언트) 측에 다른 스크립팅 언어가 있습니까?

name = null;

당신 : 무엇입니까 name?
JavaScript : 모르겠습니다.

한마디로; undefined사물의 개념이 존재하지 않는 곳이다. 유형이 없으며 해당 범위에서 이전에 참조 된 적이 없습니다. null일이 존재하는 것으로 알려져 있지만 그 가치가 무엇인지는 알 수 없습니다.

기억해야 할 한 가지 즉 null, 개념적,하지와 동일 false또는 ""그들이 타입 캐스팅, 즉 후 동일시하는 경우에도, 또는

name = false;

당신 : 무엇입니까 name?
JavaScript : 부울 false.

name = '';

당신 : 무엇입니까 name?
자바 스크립트 : 빈 문자열


* : name이 문맥에서 정의 된 적이없는 변수를 의미합니다. 정의되지 않은 변수 일 수 있지만 name은 HTML 양식 요소의 속성입니다. 그것은 길을 거슬러 올라가고 신분증 앞에 잘 세워졌습니다. ID는 고유해야하지만 이름은 필요하지 않기 때문에 유용합니다.


답변

차이점은이 스 니펫에 요약 할 수 있습니다.

alert(typeof(null));      // object
alert(typeof(undefined)); // undefined

alert(null !== undefined) //true
alert(null == undefined)  //true

확인 중

object == null확인하는 것과 다릅니다 if ( !object ).

! Boolean(object)단항 !연산자는 오른쪽 피연산자를 자동으로 부울로 캐스팅 하기 때문에 후자는 입니다.

Boolean(null)false와 같으 므로 !false === true.

따라서 객체가 null아니라 false 또는 0 또는 “” 인 경우 다음과 같은 이유로 검사가 통과됩니다.

alert(Boolean(null)) //false
alert(Boolean(0))    //false
alert(Boolean(""))   //false


답변

null객체가 아닌 , 그것을 인 프리미티브 값 . 예를 들어 속성을 추가 할 수 없습니다. 때로는 사람들이 객체를 객체라고 가정 typeof null합니다 "object". 그러나 이것은 실제로 버그입니다 (ECMAScript 6에서 수정 될 수도 있음).

차이 nullundefined같은 다음이다 :

  • undefined: JavaScript에서 사용되며 “값 없음”을 의미합니다. 초기화되지 않은 변수, 누락 된 매개 변수 및 알 수없는 변수에는 해당 값이 있습니다.

    > var noValueYet;
    > console.log(noValueYet);
    undefined
    
    > function foo(x) { console.log(x) }
    > foo()
    undefined
    
    > var obj = {};
    > console.log(obj.unknownProperty)
    undefined

    그러나 알 수없는 변수에 액세스하면 예외가 발생합니다.

    > unknownVariable
    ReferenceError: unknownVariable is not defined
  • null: 프로그래머가 “값 없음”을 표시하기 위해 사용합니다 (예 : 함수의 매개 변수).

변수 검사 :

console.log(typeof unknownVariable === "undefined"); // true

var foo;
console.log(typeof foo === "undefined"); // true
console.log(foo === undefined); // true

var bar = null;
console.log(bar === null); // true

일반적으로 JavaScript에서는 항상 ===를 사용하고 절대 ==를 사용하지 않아야합니다 (== 는 예기치 않은 결과를 생성 할 수있는 모든 종류의 변환 을 수행함 ). 이 검사 x == null는 다음 nullundefined같이 작동하기 때문에 가장 중요한 경우입니다 .

> null == null
true
> undefined == null
true

변수에 값이 있는지 확인하는 일반적인 방법은 변수를 부울로 변환하여 값인지 확인하는 것입니다 true. 이 변환은 if명령문과 부울 연산자 로 수행됩니다 ! (“아니”).

function foo(param) {
    if (param) {
        // ...
    }
}
function foo(param) {
    if (! param) param = "abc";
}
function foo(param) {
    // || returns first operand that can't be converted to false
    param = param || "abc";
}

이 방법의 단점 : 다음과 같은 값으로 평가 모두의 false당신이 (예를 들어, 위의 수표를 구별 할 수 없습니다주의해야합니다, 그래서 undefined하고 0).

  • undefined, null
  • 부울 : false
  • 숫자 : +0, -0,NaN
  • 문자열 : ""

Boolean함수 로 사용하여 부울로의 변환을 테스트 할 수 있습니다 (일반적으로와 함께 사용되는 생성 자임 new).

> Boolean(null)
false
> Boolean("")
false
> Boolean(3-3)
false
> Boolean({})
true
> Boolean([])
true


답변

null과 undefined의 차이점은 무엇입니까 ??

정의가없는 속성은 정의되지 않습니다. null은 객체입니다. 유형은 객체입니다. null은 “값 없음”을 의미하는 특수한 값입니다. undefined는 객체가 아니며 유형은 정의되지 않습니다.

변수를 선언하고 null로 설정하면 “null”이 출력되고 “undefined”가 표시되는 것을 제외하고는 동작이 동일합니다. 정의되지 않은 변수를 null로 또는 그 반대로 비교할 수도 있으며 조건은 true입니다.

 undefined == null
 null == undefined

자세한 내용 은 null과 undefined의 JavaScript 차이를 참조하십시오 .

그리고 새로운 편집으로

if (object == null)  does mean the same  if(!object)

object가 false 인 경우 테스트 할 때 false 인 경우 테스트 할 때만 조건을 충족 하지만 true 인 경우

여기를 확인하십시오 : Javascript gotcha


답변

질문의 첫 부분 :

JavaScript에서 null이 객체로 간주되는 이유는 무엇입니까?

그들이 지금 고칠 수없는 JavaScript 디자인 오류입니다. 유형이 아니거나 유형이 아니어야합니다. 실제 객체를 감지 할 때 추가 검사 (때로는 잊혀짐)가 필요하며 버그의 원인입니다.

질문의 두 번째 부분 :

if (object == null)
Do something

같은 검사

if (!object)
Do something

두 가지 검사는 다음을 제외하고 항상 모두 거짓입니다.

  • object가 정의되지 않았거나 null 인 경우 모두 true입니다.

  • object가 프리미티브이고 0, ""또는 false : 첫 번째 확인 false, 두 번째 true.

객체가 프리미티브가 아니라 실제 객체 (예 new Number(0): new String(""), 또는) new Boolean(false)인 경우 두 검사는 모두 거짓입니다.

따라서 ‘object’가 실제 Object를 의미하는 것으로 해석되면 두 검사는 항상 동일합니다. 프리미티브가 허용되면 검사는 0 "", 및 false에 대해 다릅니다 .

과 같은 object==null경우, 명백하지 않은 결과는 버그의 원인이 될 수 있습니다. 사용을 ==권장하지 않으며 ===대신 사용하십시오.

질문의 세 번째 부분 :

또한

null과 undefined의 차이점은 무엇입니까?

JavaScript에서 한 가지 차이점은 null은 object 유형이고 undefined는 undefined 유형입니다.

JavaScript에서는 null==undefinedtrue이며 type이 무시되면 동일한 것으로 간주됩니다. 왜 그들이 결정했지만 0 ""과 거짓이 같지 않은지 모르겠습니다. 임의의 의견 인 것 같습니다.

JavaScript에서는 null===undefined형식이에서 동일해야하므로 true가 아닙니다 ===.

실제로 null과 undefined는 모두 존재하지 않기 때문에 동일합니다. 따라서 0 ""도 마찬가지 입니다. 빈 컨테이너 []{}. 같은 종류의 많은 것들이 버그의 레시피입니다. 하나의 유형 또는 전혀없는 것이 좋습니다. 가능한 한 적게 사용하려고합니다.

‘false’, ‘true’및 ‘!’ 예를 들어, 간단하게 할 수있는 웜의 또 다른 가방입니다, if(!x)그리고 if(x)혼자 충분합니다, 당신은 진실과 거짓 필요가 없습니다.

선언 된 var x값은 값이 제공되지 않으면 undefined 유형이지만 x가 전혀 선언되지 않은 것과 동일해야합니다. 또 다른 버그 소스는 비어있는 컨테이너입니다. 따라서 같이 선언하고 정의하는 것이 가장 좋습니다 var x=1.

사람들은이 모든 다양한 유형의 아무것도 알아 내려고 애 쓰면서 빙글 빙글 돌고 있지만 복잡한 옷을 입는 것만 똑같습니다. 현실은

undefined===undeclared===null===0===""===[]==={}===nothing

그리고 아마도 모두 예외를 던져야 할 것입니다.


답변

var x = null;

x는 null로 정의

y는 정의되어 있지 않습니다. // 정의하지 않았기 때문에

if (!x)

null은 거짓으로 평가된다


답변

null 및 undefined를 이해하는 한 가지 방법은 각각의 발생 위치를 이해하는 것입니다.

다음 상황에서는 널 리턴 값이 필요합니다.

  • DOM을 쿼리하는 메소드

    console.log(window.document.getElementById("nonExistentElement"));
    //Prints: null
  • Ajax 요청에서받은 JSON 응답


    {
      name: "Bob",
      address: null
    }
  • RegEx.exec .

  • 플럭스 상태에있는 새로운 기능. 다음은 null을 반환합니다.


        var proto = Object.getPrototypeOf(Object.getPrototypeOf({}));

       // But this returns undefined:

        Object.getOwnPropertyDescriptor({}, "a");

존재하지 않는 다른 모든 경우는 정의되지 않은 것으로 표시됩니다 (@Axel로 표시). 다음은 “정의되지 않은”인쇄입니다.

    var uninitalised;
    console.log(uninitalised);

    var obj = {};
    console.log(obj.nonExistent);

    function missingParam(missing){
        console.log(missing);
    }

    missingParam();

    var arr = [];
    console.log(arr.pop());        

당연히 var unitialised = null; 또는 메서드에서 직접 null을 반환하면 다른 상황에서 null이 발생합니다. 그러나 그것은 분명합니다.

세 번째 경우는 변수에 액세스하고 싶지만 선언되었는지조차 모르는 경우입니다. 이 경우 typeof를 사용하여 참조 오류를 피하십시오.

if(typeof unknown !== "undefined"){
    //use unknown
}

요약하면 DOM을 조작하거나 Ajax를 다루거나 특정 ECMAScript 5 기능을 사용할 때 null을 확인하십시오. 다른 모든 경우에 대해 엄격한 평등으로 정의되지 않은 것을 확인하는 것이 안전합니다.

if(value === undefined){
  // stuff
}