JavaScript中 typeof运算符 详解

简介:

typeof运算符介绍:
typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。
它返回值是一个字符串,该字符串说明运算数的类型。 

你知道下面typeof运算的结果吗?

    typeof(1);  
    typeof(NaN);  
    typeof(Number.MIN_VALUE);  
    typeof(Infinity);  
    typeof("123");  
    typeof(true);  
    typeof(window);  
    typeof(document);  
    typeof(null);  
    typeof(eval);  
    typeof(Date);  
    typeof(sss);  
    typeof(undefined);  

看看你会几个?



看了以后,不是很明白的话,请看下面(明白的人就不用浪费时间了,呵呵):


typeof是一个一元运算符,它返回的结果始终是一个字符串,对不同的操作数,它返回不同的结果。


具体的规则如下:


一、对于数字类型的操作数而言, typeof 返回的值是 number。比如说:typeof(1),返回的值就是number。


上面是举的常规数字,对于非常规的数字类型而言,其结果返回的也是number。比如typeof(NaN),NaN在


JavaScript中代表的是特殊非数字值,虽然它本身是一个数字类型。


在JavaScript中,特殊的数字类型还有几种:


Infinity 表示无穷大特殊值


NaN            特殊的非数字值


Number.MAX_VALUE     可表示的最大数字


Number.MIN_VALUE     可表示的最小数字(与零最接近)


Number.NaN        特殊的非数字值


Number.POSITIVE_INFINITY 表示正无穷大的特殊值


Number.NEGATIVE_INFINITY  表示负无穷大的特殊值


以上特殊类型,在用typeof进行运算进,其结果都将是number。



二、对于字符串类型, typeof 返回的值是 string。比如typeof("123")返回的值是string。


三、对于布尔类型, typeof 返回的值是 boolean 。比如typeof(true)返回的值是boolean。


四、对于对象、数组、null 返回的值是 object 。比如typeof(window),typeof(document),typeof(null)返回的值都是object。


五、对于函数类型,返回的值是 function。比如:typeof(eval),typeof(Date)返回的值都是function。


六、如果运算数是没有定义的(比如说不存在的变量、函数或者undefined),将返回undefined。比如:typeof(sss)、typeof(undefined)都返回undefined。     


    <script>  
        document.write ("typeof(1): "+typeof(1)+"<br>"); 
        document.write ("typeof(NaN): "+typeof(NaN)+"<br>"); 
        document.write ("typeof(Number.MIN_VALUE): "+typeof(Number.MIN_VALUE)+"<br>") 
        document.write ("typeof(Infinity): "+typeof(Infinity)+"<br>") 
        document.write ("typeof(\"123\"): "+typeof("123")+"<br>") 
        document.write ("typeof(true): "+typeof(true)+"<br>") 
        document.write ("typeof(window): "+typeof(window)+"<br>") 
        document.write ("typeof(document): "+typeof(document)+"<br>") 
        document.write ("typeof(null): "+typeof(null)+"<br>") 
        document.write ("typeof(eval): "+typeof(eval)+"<br>") 
        document.write ("typeof(Date): "+typeof(Date)+"<br>") 
        document.write ("typeof(sss): "+typeof(sss)+"<br>") 
        document.write ("typeof(undefined): "+typeof(undefined)+"<br>") 
    </script>  

呵呵,每天进步一点点,一年以后不得了哦!




      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/925217,如需转载请自行联系原作者




相关文章
|
23天前
|
机器学习/深度学习 JavaScript 前端开发
JavaScript typeof, null, 和 undefined
JavaScript typeof, null, 和 undefined
39 4
|
25天前
|
JavaScript 前端开发
JavaScript 运算符
JavaScript 运算符
15 3
|
2月前
|
JavaScript 前端开发
JavaScript 中的 typeof 运算符
【8月更文挑战第29天】
16 1
|
2月前
|
JavaScript 前端开发 安全
深入理解JavaScript中的比较运算符
深入理解JavaScript中的比较运算符
|
2月前
|
前端开发 JavaScript 程序员
聊聊前端 JavaScript 的扩展运算符 “...“ 的使用场景
聊聊前端 JavaScript 的扩展运算符 “...“ 的使用场景
|
2月前
|
JavaScript 前端开发
JavaScript基础&实战(2)js中的强制类型转换、运算符、关系运算符、逻辑运算符、条件运算符
这篇文章详细介绍了JavaScript中的强制类型转换、运算符(包括算术、逻辑、条件、赋值和关系运算符)的使用方法和优先级规则。
JavaScript基础&实战(2)js中的强制类型转换、运算符、关系运算符、逻辑运算符、条件运算符
|
2月前
|
JavaScript 前端开发
js确定数据类型typeof与instanceof
js确定数据类型typeof与instanceof
25 0
|
3月前
|
JavaScript 前端开发 网络架构
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
49 1
|
3月前
|
JavaScript
js【详解】typeof 运算符
js【详解】typeof 运算符
17 0
|
3月前
|
JavaScript 前端开发 数据安全/隐私保护