例如我随便定义一个变量 :
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); } };