jQuery1.6 類型判斷實現(xiàn)代碼
更新時間:2011年09月01日 20:57:36 作者:
jQuery1.6 類型判斷實現(xiàn)代碼,學習jquery的朋友可以參考下。
首先定義了
全局變量class2type = {};
rdigit = /\d/,//正則判斷是否是數(shù)字
toString = Object.prototype.toString;
通過jQuery.each,定義class2type的屬性和值:
jQuery.each("Boolean Number String Function Array Date RegExp Object".split(" "), function(i, name) {
class2type[ "[object " + name + "]" ] = name.toLowerCase();
});
type: function( obj ) {
return obj == null ?String( obj ) :class2type[ toString.call(obj) ] || "object";//js 里一切都是對象,所以可以用toString.call(obj)返回對應對象類型
//如果直接使用這個方法來判斷類型的話,IE下document.getElementById認為是object,其他瀏覽器則認為是function
//如果傳入的值是NaN的話,會返回"number"
}
isFunction: function( obj ) {return jQuery.type(obj) === "function";}//在IE下,如果傳入document.getElementById,返回的是false,IE為它是object
isArray: Array.isArray || function( obj ) {return jQuery.type(obj) === "array";}//如果原生Array擁有isArray方法則使用Array.isArray,否則自定義這個方法
isWindow: function( obj ) {return obj && typeof obj === "object" && "setInterval" in obj;}//判斷是否為window對象
isNaN: function( obj ) {return obj == null || !rdigit.test( obj ) || isNaN( obj );}//
isEmptyObject: function( obj ) {
for ( var name in obj ) {//判斷的依據是看對象是否有屬性或者方法
return false;
}
return true;
}
全局變量class2type = {};
rdigit = /\d/,//正則判斷是否是數(shù)字
toString = Object.prototype.toString;
通過jQuery.each,定義class2type的屬性和值:
復制代碼 代碼如下:
jQuery.each("Boolean Number String Function Array Date RegExp Object".split(" "), function(i, name) {
class2type[ "[object " + name + "]" ] = name.toLowerCase();
});
type: function( obj ) {
return obj == null ?String( obj ) :class2type[ toString.call(obj) ] || "object";//js 里一切都是對象,所以可以用toString.call(obj)返回對應對象類型
//如果直接使用這個方法來判斷類型的話,IE下document.getElementById認為是object,其他瀏覽器則認為是function
//如果傳入的值是NaN的話,會返回"number"
}
isFunction: function( obj ) {return jQuery.type(obj) === "function";}//在IE下,如果傳入document.getElementById,返回的是false,IE為它是object
isArray: Array.isArray || function( obj ) {return jQuery.type(obj) === "array";}//如果原生Array擁有isArray方法則使用Array.isArray,否則自定義這個方法
isWindow: function( obj ) {return obj && typeof obj === "object" && "setInterval" in obj;}//判斷是否為window對象
isNaN: function( obj ) {return obj == null || !rdigit.test( obj ) || isNaN( obj );}//
isEmptyObject: function( obj ) {
for ( var name in obj ) {//判斷的依據是看對象是否有屬性或者方法
return false;
}
return true;
}
相關文章
jQuery實現(xiàn)使用sort方法對json數(shù)據排序的方法
這篇文章主要介紹了jQuery實現(xiàn)使用sort方法對json數(shù)據排序的方法,涉及jQuery基于ajax針對json格式文件數(shù)據的動態(tài)載入與排序相關操作技巧,需要的朋友可以參考下2018-04-04Jquery Ajax學習實例 向頁面發(fā)出請求,返回XML格式數(shù)據
Jquery Ajax學習實例 向頁面發(fā)出請求,返回XML格式數(shù)據的代碼2010-03-03jquery進行數(shù)組遍歷如何跳出當前的each循環(huán)
通過 jquery 的循環(huán)方法進行數(shù)組遍歷,但是當不符合條件時,怎么跳出當前循環(huán),解決方法如下,需要的朋友可以參考下2014-06-06jQuery實現(xiàn)下拉菜單(內容為時間)的實時更新及圖表的隨動更新的方法
這篇文章主要介紹了實現(xiàn)下拉菜單(內容為時間)的實時更新及圖表的隨動更新的方法的相關資料,需要的朋友可以參考下2016-07-07jQuery Easyui datagrid連續(xù)發(fā)送兩次請求問題
用上述方式動態(tài)加載datagrid的數(shù)據時,通過net監(jiān)聽,發(fā)現(xiàn)調用了兩遍XX方法,目前的解決方案是,將url放到datagrid初始化的時候執(zhí)行2016-12-12