本文实例讲述了javascript中的基本数据类型以及类型检测的几种方法。分享给大家供大家参考,具体如下:@H_403_1@
1.JS中有6种基本的数据类型,JS中的所有操作都是基于这五种基本类型得到的。@H_403_1@
403_1@
对象类型@H_403_1@
403_1@
数字类型@H_403_1@
403_1@
字符串类型@H_403_1@
403_1@
403_1@
403_1@
布尔类型:true或者为false@H_403_1@
I)JS中的数据类型转换(非严格模式下)@H_403_1@
II)JS中的数据类型转换(非严格模式下)@H_403_1@
上述中的等号均不成立@H_403_1@
注:特别的如果为基本类型中的string或者number,在必要的情况下,可以将string或者number转化为对象object类型,转化不是持续的。@H_403_1@
比如:@H_403_1@
数据类型中的隐式转化补充:@H_403_1@
(1)通过typeof来进行类型检测@H_403_1@
我们先来看几个例子:@H_403_1@
number@H_403_1@
string@H_403_1@
boolean@H_403_1@
function@H_403_1@
object@H_403_1@
function@H_403_1@
object@H_403_1@
underfined@H_403_1@
注:我们发现typeof null,结果返回了object,这是一个很早之前的BUG,一直沿用至今@H_403_1@
试用范围:如果通过typeof来判断类型,适用于判定基本类型,或者判断是否为函数(function)。@H_403_1@
2.instanceof@H_403_1@
同样举例来说明:@H_403_1@
true@H_403_1@
false@H_403_1@
总结:instanceof 会沿着原型链查找,如果左边对象的原型链上,具有右边的对象,那么会返回true,并且注意只用于判断扩展的对象类型(非number,string等)@H_403_1@
比如:@H_403_1@
false
"hell" instanceof String ------>string@H_403_1@
补充:instanceof的右边必须是函数,或者是构造器,如果不是则会报错,检测的是左边的对象的原型链上,是否有右边函数的prototype。@H_403_1@
3.Object.prototype.toString@H_403_1@
通过对象原型上的toSting方法,同样也可以判断类型,我们来举例子:@H_403_1@
[object Object]@H_403_1@
[object Function]@H_403_1@
[object Function]@H_403_1@
[object Function]@H_403_1@
[object Null]@H_403_1@
[object Undefined]@H_403_1@
使用类型:原生对象和基本类型@H_403_1@
此外还有@H_403_1@
(4)constructor@H_403_1@
(5)duck type等@H_403_1@
更多关于JavaScript相关内容可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》@H_403_1@
希望本文所述对大家JavaScript程序设计有所帮助。@H_403_1@总结:
如果右边的是基本类型,则typeof会尝试得到最基本的类型,比如number,string等等,如果是函数名,那么则返回function,这里Object,Number,String,等等都可以看成函数名,如果右边是一个基本的对象,则返回object(返回的都是小写哦)。@H_403_1@