<strike id="g3zqm"></strike>

      <cite id="g3zqm"></cite>

        <tr id="g3zqm"><center id="g3zqm"></center></tr>
        <pre id="g3zqm"><sup id="g3zqm"></sup></pre>
        <li id="g3zqm"></li>
      1. 少妇高潮激情一区二区三,免费av深夜在线观看,亚洲狼人久久伊人久久伊,久久精品人人做人人爽电影蜜月,黄色特级片一区二区三区,欧美日韩在线亚洲二区综二,极品少妇无套内射视频,日本极品少妇videossexhd

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

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

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

        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)上很多都是如上的說法,但是會存在一個(gè)問題,就是如果obj=null ,obj=undefinedobj=""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()); // 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=undefinedobj=""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() 方法返回一個(gè)由指定對象的所有自身屬性的屬性名(包括不可枚舉屬性但不包括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() 方法會返回一個(gè)由一個(gè)給定對象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和使用 for...in循環(huán)遍歷該對象時(shí)返回的順序一致 。

        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

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

        藍(lán)藍(lán)設(shè)計(jì)m.hengshangtqd.cn )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國內(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ù)

        日歷

        鏈接

        個(gè)人資料

        存檔

        主站蜘蛛池模板: 久久天天久久| 农村欧美丰满熟妇xxxx| 国产精品一线天粉嫩av| 国产????XX高清| 亚洲无码一二| 无码熟妇人妻av| 国产良妇出轨视频在线观看| 日韩精品一区二区三区激| 巨胸不知火舞露双奶头无遮挡| 小泽玛利亚区二区在线| 色综合天天综合高清网国产在线| 一区二区三区四区五区色| 97久久综合亚洲色hezyo| 日韩欧美一卡2卡3卡4卡无卡免费2020| 中文字幕久久精品无码综合网| 国产成人精品无码专区| 亚洲国产超清无码专区| 亚洲欧美偷国产日韩| 久热这里有精品视频播放| 先锋影音人妻啪啪VA资源网站| 亚洲色天堂网| 久久夜色精品国产欧美| 国模吧一区| 欧美疯狂xxxxbbbb喷潮| 亚洲第一狼人成人综合网| 国产中文字幕在线一区| 国产精品一亚洲AV日韩AV欧| 国产乱人伦1区2区3区| 午夜A理论片在线播放| 在线视频福利导航| 亚洲中文久久久精品无码| 一本色道久久加勒比综合| 99在线观看视频| 欧美色综合天天久久综合精品 | 日本一卡2卡3卡四卡精品网站| 亚洲精品不卡av在线播放| 精品国产国产2021| 拍真实国产伦偷精品| 阿合奇县| 少妇下面好紧好多水真爽播放| 日产无码中文字幕AV|