欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript基本数据类型及类型检测常用方法小结

程序员文章站 2022-06-13 10:38:38
本文实例讲述了javascript中的基本数据类型以及类型检测的几种方法。分享给大家供大家参考,具体如下: 1.js中有6种基本的数据类型,js中的所有操作都是基于这五种...

本文实例讲述了javascript中的基本数据类型以及类型检测的几种方法。分享给大家供大家参考,具体如下:

1.js中有6种基本的数据类型,js中的所有操作都是基于这五种基本类型得到的。

(1)object

对象类型

(2)number

数字类型

(3)string

字符串类型

(4)null

(5)underfined

(6)boolean

布尔类型:true或者为false

i)js中的数据类型转换(非严格模式下)

“12”==12 // true 在非严格模式下,字符串可以向数字转换
true==1 // true 布尔值在等号两边会尝试转换为0或者1
“1”==true //true
null==underfined //true
new object()==new object() //true
nan==nan //false

ii)js中的数据类型转换(非严格模式下)

上述中的等号均不成立

注:特别的如果为基本类型中的string或者number,在必要的情况下,可以将string或者number转化为对象object类型,转化不是持续的。

比如:

var x=”hello” ; alert(a.length) // 5

数据类型中的隐式转化补充:

“32”+32 //转化为string
"32"-32 //转化为number

js中的类型检测方法

(1)通过typeof来进行类型检测

我们先来看几个例子:

typeof 100 —->number

typeof “hello” ——>string

typeof true —–> boolean

typeof number ——>function

typeof new object()——->object

typeof object ——->function

typeof null ——–>object

typeof underfined ——–>underfined

总结:如果右边的是基本类型,则typeof会尝试得到最基本的类型,比如number,string等等,如果是函数名,那么则返回function,这里object,number,string,等等都可以看成函数名,如果右边是一个基本的对象,则返回object(返回的都是小写哦)。

注:我们发现typeof null,结果返回了object,这是一个很早之前的bug,一直沿用至今

试用范围:如果通过typeof来判断类型,适用于判定基本类型,或者判断是否为函数(function)。

2.instanceof

同样举例来说明:

[1,2] instanceof array ——> true

“1,2” instanceof array ——->false

总结:instanceof 会沿着原型链查找,如果左边对象的原型链上,具有右边的对象,那么会返回true,并且注意只用于判断扩展的对象类型(非number,string等)

比如:

instanceof number —–> false
"hell"  instanceof string  ------>string

补充:instanceof的右边必须是函数,或者是构造器,如果不是则会报错,检测的是左边的对象的原型链上,是否有右边函数的prototype。

3.object.prototype.tostring

通过对象原型上的tosting方法,同样也可以判断类型,我们来举例子:

object.prototype.tostring.apply([]) ——>[object object]

object.prototype.tostring.apply(function(){}) —->[object function]

object.prototype.tostring.apply(number) ——->[object function]

object.prototype.tostring.apply(string) ——–>[object function]

object.prototype.tostring.apply(null) ———–>[object null]

object.prototype.tostring.apply(undefined)–>[object undefined]

使用类型:原生对象和基本类型

此外还有

(4)constructor

(5)duck type等

更多关于javascript相关内容可查看本站专题:《javascript面向对象入门教程》、《javascript中json操作技巧总结》、《javascript切换特效与技巧总结》、《javascript查找算法技巧总结》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。