论坛首页 Web前端技术论坛

JS 对象 1.类型的判断

浏览 1633 次
精华帖 (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);
	}
};

  

 

 

 

   

论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics