浏览 1633 次
锁定老帖子 主题:JS 对象 1.类型的判断
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-11-03
最后修改:2010-01-05
例如我随便定义一个变量 :
var str = 'ssss'; var num = 78;
在运行下面代码后 :
alert(obj.constructor.toString()); JS的弱变量定义就其作用了 : str ==> String 对象 ,num ==> Number对象.
弱变量的定义,会在运行的时候动态赋予类型 class . 我们一般可以通过构造属性constructor 知道obj是什么类型
当我们 new 对象的时候 可以通过instanceof 运算符 判断它是否是特定类型的一个实例:
var str = new String('ssss'); var num = new Number(78); 用下面方式判断都是 :
alert(num instanceof Number) alert(num instanceof Object) 结果都是ture
还有 typeof 运算符 ,判断变量的类型 var str = 'ssss'; var num = 78; alert(str.constructor.toString()); //String alert(num.constructor.toString()); // Number alert( num instanceof Object);//false if((typeof str ) == 'string'){ alert('is String type'); // }
如果我们想判断一个参数的类型是什么,可以下面方式 Check.type = { isArray : function (obj) { return obj && (obj.constructor.toString().indexOf("Array") != -1); }, isFunction : function (obj) { return obj && (obj.constructor.toString().indexOf("Function") != -1); }, isObject : function (obj) { return obj && ((obj.constructor) ? (obj.constructor.toString().indexOf("Object") != -1) : (typeof obj == 'object')); }, isString : function (obj) { return obj != null && (obj.constructor.toString().indexOf("String") != -1); }, isNumber : function (obj) { return obj && (obj.constructor.toString().indexOf("Number") != -1); }, isBoolean : function (obj) { return obj && (obj.constructor.toString().indexOf("Boolean") != -1); } };
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |