Home > Web Front-end > JS Tutorial > Detailed explanation of usage examples of the difference between undefined, null, NaN, etc. in JavaScript

Detailed explanation of usage examples of the difference between undefined, null, NaN, etc. in JavaScript

伊谢尔伦
Release: 2017-07-18 13:43:36
Original
1413 people have browsed it

The difference between undefined, null and NaN in js

1. Type analysis:
The data types in js include undefined, boolean, number, There are 5 types such as string and object. The first 4 types are primitive types, and the fifth type is reference type.

var a1;
var a2 = true;
var a3 = 1;
var a4 = "Hello";
var a5 = new Object();
var a6 = null;
var a7 = NaN;
var a8 = undefined;
alert(typeof a);    //显示"undefined"
alert(typeof a1); //显示"undefined"
alert(typeof a2); //显示"boolean"
alert(typeof a3); //显示"number"
alert(typeof a4); //显示"string"
alert(typeof a5); //显示"object"
alert(typeof a6); //显示"object"
alert(typeof a7); //显示"number"
alert(typeof a8); //显示"undefined"
Copy after login

It can be seen from the above code that undefined values ​​and unassigned values ​​are undefined, null is a special object, and NaN is a special number.

2. Comparison operation

var a1;         //a1的值为undefined
var a2 = null;
var a3 = NaN;
alert(a1 == a2); //显示"true"
alert(a1 != a2); //显示"false"
alert(a1 == a3); //显示"false"
alert(a1 != a3); //显示"true"
alert(a2 == a3); //显示"false"
alert(a2 != a3); //显示"true"
alert(a3 == a3); //显示"false"
alert(a3 != a3); //显示"true"
Copy after login

From the above code we can draw the conclusion: (1) undefined and null are equal; (2) NaN and any The values ​​are not equal, nor are they equal to themselves.

JavaScript undefined attribute

Definition and usage
The undefined attribute is used to store the undefined value of JavaScript.

Syntax
undefined

Explanation
You cannot use for/in loops to enumerate undefined properties, nor can you use the delete operation character to delete it.
undefined is not a constant and can be set to other values.
Undefined will also be returned when trying to read non-existent object properties.

Tips and Notes
Tip: You can only use the === operator to test whether a value is undefined, because the == operator considers the undefined value to be equivalent to null .
Note: null means no value, and undefined means an undeclared variable, or a variable that has been declared but has no value assigned, or an object property that does not exist.

Example
In this example, we will detect that one of the two variables is undefined:

<script type="text/javascript">
var t1=""
var t2
if (t1===undefined) {document.write("t1 is undefined")}
if (t2===undefined) {document.write("t2 is undefined")}
</script>
Copy after login

Output:
t2 is undefined

Judgment undefined:

<span style="font-size: small;">var tmp = undefined; 
if (typeof(tmp) == "undefined"){ 
alert("undefined"); 
}</span>
Copy after login

Judgment null:

<span style="font-size: small;">var tmp = null; 
if (!tmp && typeof(tmp)!="undefined" && tmp!=0){ 
alert("null"); 
} </span>
Copy after login

Judgment NaN:

<span style="font-size: small;">var tmp = 0/0; 
if(isNaN(tmp)){ 
alert("NaN"); 
}</span>
Copy after login

Description: If NaN is combined with any value (including itself) The results obtained by comparison are all false, so to determine whether a value is NaN, you cannot use the == or === operator.

Tip: The isNaN() function is usually used to detect the results of parseFloat() and parseInt() to determine whether they represent legal numbers. Of course, you can also use the isNaN() function to detect arithmetic errors, such as using 0 as a divisor.

The above is the detailed content of Detailed explanation of usage examples of the difference between undefined, null, NaN, etc. in JavaScript. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template