国产精品美女久久久浪潮AV,国产精品三级一二三区,久久精品国产一区二区小说 ,依依成人影视国产精品,全部无卡免费的毛片在线看,日本一区二区三深夜不卡,国产精品女同一区二区久久,国产精品夜色一区二区三区

        JavaScript判斷變量是否為空對象 {} 的幾種方法

        2018-8-20    seo達(dá)人

        如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點這里

        json對象轉(zhuǎn)化為json字符串,再判斷該字符串是否為"{}"

        var obj = {}; var b = (JSON.stringify(obj) === "{}");
        console.log(b); // true
            
        • 1
        • 2
        • 3

        for in 循環(huán)判斷

        var obj = {}; var b = function() { for(var key in obj) { return false;
            } return true;
        }
        console.log(b()); // true
            
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8

        網(wǎng)上很多都是如上的說法,但是會存在一個問題,就是如果obj=null ,obj=undefinedobj="",obj=[]obj=0 以及obj為任意數(shù)字也返回true,所以有了下面這個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()); // true
            
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
        • 9
        • 10
        • 11

        方案二:

        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()); // true
            
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
        • 9
        • 10
        • 11

        上面兩種方案的區(qū)別就是判斷判斷空數(shù)組的方式不同。

        jQuery的jQuery.isEmptyObject(obj)方法

        var obj = {}; var b = $.isEmptyObject(obj);
        console.log(b); // true
            
        • 1
        • 2
        • 3

        jQuery.isEmptyObject(obj) 方法依然存在obj=null ,obj=undefined,obj="",obj=[]obj=0 以及obj為任意數(shù)字返回true的問題,所以我們還應(yīng)該再用typeof 或者 $.type() 判斷一下:

        var obj = {}; var b = $.isEmptyObject(obj) && $.type(obj) === "object";
        console.log(b); // true
            
        • 1
        • 2
        • 3
        var obj = {}; var b = $.isEmptyObject(obj) && typeof obj === "object" && obj !== null && !Array.isArray(obj);
        console.log(b); // true
            
        • 1
        • 2
        • 3
        var obj = {}; var b = $.isEmptyObject(obj) && typeof obj === "object" && obj !== null && Object.prototype.toString.call(obj) !== "[object Array]";
        console.log(b); // true
            
        • 1
        • 2
        • 3

        Object.getOwnPropertyNames()方法

        Object.getOwnPropertyNames() 方法返回一個由指定對象的所有自身屬性的屬性名(包括不可枚舉屬性但不包括Symbol值作為名稱的屬性)組成的數(shù)組。

        var obj = {}; var b = !Object.getOwnPropertyNames(obj).length;
        console.log(b); // true
            
        • 1
        • 2
        • 3

        Object.getOwnPropertyNames() 方法存在obj=0 以及obj為任意數(shù)字返回true的問題,所以我們還應(yīng)該再用typeof 判斷一下:

        var obj = {}; var b = !Object.getOwnPropertyNames(obj).length && typeof obj === "object";
        console.log(b); // true
            
        • 1
        • 2
        • 3

        Object.keys()方法

        Object.keys() 方法會返回一個由一個給定對象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和使用 for...in循環(huán)遍歷該對象時返回的順序一致 。

        var obj = {}; var b = !Object.keys(obj).length;
        console.log(b); // true
            
        • 1
        • 2
        • 3

        Object.keys() 方法存在obj="",obj=[]obj=0 以及obj為任意數(shù)字返回true的問題,所以依舊需要加判斷如下:

        var obj = {}; var b = !Object.keys(obj).length && typeof obj === "object" && !Array.isArray(obj);
        console.log(b); // true
            
        • 1
        • 2
        • 3
        var obj = {}; var b = !Object.keys(obj).length && typeof obj === "object" && Object.prototype.toString.call(obj) !== "[object Array]";
        console.log(b); // true
            
        • 1
        • 2
        • 3

        在實際應(yīng)用中,如果對象不為空,并且知道對象不為空時,某個屬性一定存在,則直接判斷這個對象的此屬性是否存在。

        藍(lán)藍(lán)設(shè)計www.shtzxx.cn )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù)

        日歷

        鏈接

        個人資料

        存檔

        主站蜘蛛池模板: 韩国午夜理论在线观看| 久久国产精品无码网站| 国产亚洲精品美女久久久m| 国产午夜福利精品久久不卡| 欧洲男同gay| 丰宁| 粗大黑人巨精大战欧美成人| 日本亚洲中文字幕不卡| 欧美国产日产一区二区| 五月婷婷综合缴情六月| 民和| 男人j进入女人j内部免费网站| xxxx日本少妇做受| 国产熟睡乱子伦视频| 伊人久久亚洲综合影院首页| 国产精品久久久久影院嫩草| 野外做受又硬又粗又大视频√| 炎陵县| 年轻人免费观看视频| 女人高潮特级毛片| 中文字幕 日韩精品 在线| 欧美性暴力变态xxxx| 西充县| 大地影院免费高清电视剧大全| 鄂托克旗| 综合无码一区二区三区| 女友被粗大的猛烈进出动漫| 青青青在线视频国产| 国产东北肥熟老胖女| 被三个室友狂躁到早上男男| 国产又爽又黄无码无遮挡在线观看| 人妻夜夜爽爽88888视频| 日韩精品亚洲人成在线观看| 主人拽奶头跪爬鞭打羞辱调教| 免费萌白酱国产一区二区三区| 老师破女学生处特级毛ooo片 | 永久免费av无码网站性色av| 人妻有码中文字幕| 九九re6热在线视频精品66| 会同县| 日韩+国产+极品|