这4种方法检验一个对象是否为空?

    互联网/前端 160次点击 · 1291天前 · 燕子
Excel表格技巧—如何统计员工的工龄?WPS文字办公—文档直接插入手机图片? 燕子

1条回答我要回复

    林老师1290天前

      如何检查一个对象是否为空呢?


      这里的空指的是对象没有自有属性


      假设这里有两个对象,一个是 obj 一个是 anotherObjlet obj1 = {
      name: 'oli',
      child: {
      name: 'oliver'
      }
      }

      let obj2 = {
      [Symbol('name')]: 'alice'
      }

      let obj3 = Object.defineProperty({}, 'name', {
      value: 'alice',
      enumerable: false
      })

      let obj4 = Object.create(null)

      // 我们需要一个函数,判断是否不含自有属性

      isEmpty(obj1) // false
      isEmpty(obj2) // false
      isEmpty(obj3) // false
      isEmpty(obj4) // true
       
      方法一:遍历for-in 遍历,并通过 hasOwnProperty 方法确认是否存在某个 key 这种方法不能够遍历到 enumerable 为 false 的属性const isEmptyObj = object => {
      if (!!Object.getOwnPropertySymbols(object).length) {
      return false
      }
      for (const key in object) {
      if (object.hasOwnProperty(key)) {
      return false
      }
      }
      return true
      }
       
      方法二:keys使用 Object 静态方法 keys 然后判断 length 即可,keys 返回的是自身可枚举属性,因此同样的不可遍历到 enumerable 为 false 的属性const isEmptyObj = object => {
      if (!!Object.getOwnPropertySymbols(object).length) {
      return false
      }
      if (Object.keys(object).length) {
      return false
      }
      return true
      }
       
      方法三:JSON使用 JSON Stringify 方法将对象转为字符串,与字符串 '{}' 对比,同样该方法无法获取到不可遍历属性const isEmptyObj = object => {
      if (!!Object.getOwnPropertySymbols(object).length) {
      return false
      }
      return JSON.stringify(object) === '{}'
      }
       
      方法四:getOwnPropertyNames使用 Object 的 getOwnPropertyNames 方法,获取所有属性名,这样就算是不可枚举属性依然能够获取到,算是比较 ok 的方法。const isEmptyObj = object => {
      if (!!Object.getOwnPropertySymbols(object).length) {
      return false
      }
      if (!!Object.getOwnPropertyNames(object).length) {
      return false
      }
      return true
      }

    请先登录后,再回复