如果您想訂閱本博客內(nèi)容,每天自動(dòng)發(fā)到您的郵箱中, 請(qǐng)點(diǎn)這里
將json
對(duì)象轉(zhuǎn)化為json
字符串,再判斷該字符串是否為"{}"
var obj = {}; var b = (JSON.stringify(obj) === "{}");
console.log(b);
for in
循環(huán)判斷
var obj = {}; var b = function() { for(var key in obj) { return false;
} return true;
}
console.log(b());
網(wǎng)上很多都是如上的說(shuō)法,但是會(huì)存在一個(gè)問(wèn)題,就是如果obj=null
,obj=undefined
,obj=""
,obj=[]
,obj=0
以及obj為任意數(shù)字也返回true,所以有了下面這個(gè)for in
循環(huán)判斷:
方案一:
var obj = {}; var b = function() { for(var key in obj) { return false;
} if(obj === null || typeof obj !== "object" || Array.isArray(obj)){ return false;
} return true;
}
console.log(b());
方案二:
var obj = {}; var b = function() { for(var key in obj) { return false;
} if(obj === null || typeof obj !== "object" || Object.prototype.toString.call(obj) === "[object Array]"){ return false;
} return true;
}
console.log(b());
上面兩種方案的區(qū)別就是判斷判斷空數(shù)組的方式不同。
jQuery的jQuery.isEmptyObject(obj)
方法
var obj = {}; var b = $.isEmptyObject(obj);
console.log(b);
jQuery.isEmptyObject(obj)
方法依然存在obj=null
,obj=undefined
,obj=""
,obj=[]
,obj=0
以及obj為任意數(shù)字返回true的問(wèn)題,所以我們還應(yīng)該再用typeof
或者 $.type()
判斷一下:
var obj = {}; var b = $.isEmptyObject(obj) && $.type(obj) === "object";
console.log(b);
var obj = {}; var b = $.isEmptyObject(obj) && typeof obj === "object" && obj !== null && !Array.isArray(obj);
console.log(b);
var obj = {}; var b = $.isEmptyObject(obj) && typeof obj === "object" && obj !== null && Object.prototype.toString.call(obj) !== "[object Array]";
console.log(b);
Object.getOwnPropertyNames()
方法
Object.getOwnPropertyNames()
方法返回一個(gè)由指定對(duì)象的所有自身屬性的屬性名(包括不可枚舉屬性但不包括Symbol值作為名稱的屬性)組成的數(shù)組。
var obj = {}; var b = !Object.getOwnPropertyNames(obj).length;
console.log(b);
Object.getOwnPropertyNames()
方法存在obj=0
以及obj為任意數(shù)字返回true的問(wèn)題,所以我們還應(yīng)該再用typeof
判斷一下:
var obj = {}; var b = !Object.getOwnPropertyNames(obj).length && typeof obj === "object";
console.log(b);
Object.keys()
方法
Object.keys()
方法會(huì)返回一個(gè)由一個(gè)給定對(duì)象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和使用 for...in
循環(huán)遍歷該對(duì)象時(shí)返回的順序一致 。
var obj = {}; var b = !Object.keys(obj).length;
console.log(b);
Object.keys()
方法存在obj=""
,obj=[]
,obj=0
以及obj為任意數(shù)字返回true的問(wèn)題,所以依舊需要加判斷如下:
var obj = {}; var b = !Object.keys(obj).length && typeof obj === "object" && !Array.isArray(obj);
console.log(b);
var obj = {}; var b = !Object.keys(obj).length && typeof obj === "object" && Object.prototype.toString.call(obj) !== "[object Array]";
console.log(b);
在實(shí)際應(yīng)用中,如果對(duì)象不為空,并且知道對(duì)象不為空時(shí),某個(gè)屬性一定存在,則直接判斷這個(gè)對(duì)象的此屬性是否存在。
藍(lán)藍(lán)設(shè)計(jì)( www.b186.net )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)。