JS 物件 1.型別的判斷

jsjqjy發表於2009-11-03

  例如我隨便定義一個變數 :

 

 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);
	}
};

  

 

 

 

   

相關文章