• <center id="sm46c"></center>
  • <dfn id="sm46c"></dfn>
  • <strike id="sm46c"></strike>
  • <cite id="sm46c"><source id="sm46c"></source></cite>
    • <strike id="sm46c"><source id="sm46c"></source></strike>
      <option id="sm46c"></option>
      国产精品天天看天天狠,女高中生强奷系列在线播放,久久无码免费的a毛片大全,国产日韩综合av在线,亚洲国产中文综合专区在,特殊重囗味sm在线观看无码,中文字幕一区二区三区四区在线,无码任你躁久久久久久老妇蜜桃

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

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

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

      json對(duì)象轉(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)上很多都是如上的說(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()); // 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的問(wèn)題,所以我們還應(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è)由指定對(duì)象的所有自身屬性的屬性名(包括不可枚舉屬性但不包括Symbol值作為名稱的屬性)組成的數(shù)組。

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

      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); // true
          
      • 1
      • 2
      • 3

      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); // true
          
      • 1
      • 2
      • 3

      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); // 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)用中,如果對(duì)象不為空,并且知道對(duì)象不為空時(shí),某個(gè)屬性一定存在,則直接判斷這個(gè)對(duì)象的此屬性是否存在。

      藍(lán)藍(lán)設(shè)計(jì)www.li-bodun.cn )是一家專注而深入的界面設(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ù)。

      日歷

      鏈接

      個(gè)人資料

      存檔

      主站蜘蛛池模板: 极品尤物一区二区三区| 麻豆精品在线播放| 亚洲高清激情一区二区三区| 亚洲色成人网站www永久尤物| 四虎在线永久免费看精品| 无码中文字幕DⅤD免费放| 2020最新国产自产精品| 57pao国产成视频免费播放| 少妇被躁爽到高潮| 国产精品不卡一区二区久久 | 依依成人影视国产精品| 狠狠亚洲色一日本高清色| 国产成人精品久久一区二区 | 欧美日本在线播放| 国产老女人精品免费视频| 人妻体体内射精一区二区| A级国产乱理伦片在线播放| 精品久久久久久中文字幕大豆网| 丁香五月亚洲综合在线国内自拍| 久久欧美一区二区三区性牲奴| 好爽好黄的视频| 2019国产在线| 亚洲AⅤ综合在线欧美一区| 日本一区二区三区18岁| 亚洲自拍偷拍一区二区三区| 最新中文字幕av无码专区| 成人无码小视频在线观看| 性色av一区二区三区人妻| 亚洲加勒比少妇无码av| 欧美亚洲综合成人A∨在线| 五月av综合av国产av| 中文 在线 日韩 亚洲 欧美| 久热久热中文字幕综合激情| 国产一区二区三区在线视頻| 天天摸夜夜添夜夜无码| 国产精品免费AⅤ片在线观看 | 狠狠色狠狠色综合网| 国产成人一区二区无码不卡在线| 久久久久中文字幕精品无码免费| 亚洲综合色区无码专区| 农村熟女大胆露脸自拍|