去除JavaScript对象中空值和空对象的四种方式

 更新时间:2023年09月18日 10:17:12   作者:MoYoon  
开发时遇到一个问题,需要将对象中的空值和空对象去除,所以这篇文章主要给大家介绍了关于去除JavaScript对象中空值和空对象的四种方式,需要的朋友可以参考下

前言

在 JavaScript 开发中,我们经常需要处理对象数据,但有时这些对象可能包含一些空值或空对象。在处理数据时,通常需要将这些空值或空对象去除,以便得到更干净、更紧凑的数据结构。本文将介绍几种方法,教你如何去除 JavaScript 对象中的空值和空对象。

方法一:使用循环和 delete 关键字

第一种方法是通过循环遍历对象的每个属性,并使用 delete 关键字从对象中删除空值或空对象。这个方法比较直接,适用于处理较小的对象。

function removeEmptyValues(obj) {
  for (const key in obj) {
    if (obj[key] === null || obj[key] === undefined) {
      delete obj[key];
    } else if (typeof obj[key] === 'object' && Object.keys(obj[key]).length === 0) {
      delete obj[key];
    }
  }
  return obj;
}
const myObject = {
  name: 'John',
  age: null,
  address: {
    city: 'New York',
    zipCode: undefined,
  },
  hobbies: [],
};
const result = removeEmptyValues(myObject);
console.log(result);
// Output: { name: 'John', address: { city: 'New York' } }

方法二:最简洁的,使用 JSON.stringify() 和 JSON.parse()

第二种方法是先将对象转换为 JSON 字符串,再将 JSON 字符串转换回对象。在这个过程中,JSON.stringify() 方法会自动去除 null 值,从而达到去除空值和空对象的效果。不过需要注意的是,这个方法会将对象中的函数非原始类型的属性转换为字符串形式,因为 JSON 只支持原始数据类型。

function removeEmptyValues(obj) {
  const jsonString = JSON.stringify(obj);
  const parsedObj = JSON.parse(jsonString);
  return parsedObj;
}
const myObject = {
  name: 'John',
  age: null,
  address: {
    city: 'New York',
    zipCode: undefined,
  },
  hobbies: [],
};
const result = removeEmptyValues(myObject);
console.log(result);
// Output: { name: 'John', address: { city: 'New York' } }

方法三:使用 Object.keys() 和 reduce()

第三种方法使用 Object.keys() 方法获取对象的所有属性键,然后使用 reduce() 方法遍历这些属性,并构建新的对象,只包含非空值的属性。

function removeEmptyValues(obj) {
  return Object.keys(obj).reduce((acc, key) => {
    if (obj[key] !== null && obj[key] !== undefined && !(typeof obj[key] === 'object' && Object.keys(obj[key]).length === 0)) {
      acc[key] = obj[key];
    }
    return acc;
  }, {});
}
const myObject = {
  name: 'John',
  age: null,
  address: {
    city: 'New York',
    zipCode: undefined,
  },
  hobbies: [],
};
const result = removeEmptyValues(myObject);
console.log(result);
// Output: { name: 'John', address: { city: 'New York' } }

方法四:最全面的,使用 Lodash 库

第四种方法使用 Lodash 库的omitBy()方法,它可以很方便地去除对象中的空值和空对象。omitBy() 方法接受一个函数作为参数,用于判断哪些属性需要被排除。

const _ = require('lodash');
const myObject = {
  name: 'John',
  age: null,
  address: {
    city: 'New York',
    zipCode: undefined,
  },
  hobbies: [],
};
const result = _.omitBy(myObject, (value) => value === null || value === undefined || (_.isObject(value) && _.isEmpty(value)));
console.log(result);
// Output: { name: 'John', address: { city: 'New York' } }

结论

本文介绍了四种方法用于去除 JavaScript 对象中的空值和空对象。通过使用循环和 delete 关键字、JSON.stringify() 和 JSON.parse()Object.keys() 和 reduce(),以及 Lodash 库的 omitBy() 方法,你可以根据项目需求选择最适合的方法。在处理大型对象时,建议使用 Lodash 库,它提供了更多的功能和灵活性。不论你选择哪种方法,去除空值和空对象能让你得到更整洁、更易读的数据,提高 JavaScript 代码的质量和可维护性。

总结

到此这篇关于去除JavaScript对象中空值和空对象的四种方式的文章就介绍到这了,更多相关JS对象中空值和空对象去除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • echarts图表设置宽度100%结果为100px的解决办法

    echarts图表设置宽度100%结果为100px的解决办法

    在开发一个前端项目时需要用到Element-ui的el-tabs组件和Echart开源库,当两者嵌套使用时,我给Echart中的图表宽度设置为了100%,但是实际的宽度却只有100px,这篇文章主要给大家介绍了关于echarts图表设置宽度100%结果为100px的解决办法,需要的朋友可以参考下
    2022-12-12
  • Js表格万条数据瞬间加载实现代码

    Js表格万条数据瞬间加载实现代码

    一条数据创建一行,如果数量大的时候,一次性要加载完数据的话,浏览器就会卡上半天,下面有个不错的方法,大家可以参考下
    2014-02-02
  • JavaScript使用setInterval()函数实现简单轮询操作的方法

    JavaScript使用setInterval()函数实现简单轮询操作的方法

    这篇文章主要介绍了JavaScript使用setInterval()函数实现简单轮询操作的方法,以实例形式分析了轮询操作的原理与javascript实现技巧,需要的朋友可以参考下
    2015-02-02
  • JS构建页面的DOM节点结构的实现代码

    JS构建页面的DOM节点结构的实现代码

    本来想用json格式的,可是要么有重复,要么得嵌套,所以改用对象嵌套数组
    2011-12-12
  • js+html获取系统当前时间

    js+html获取系统当前时间

    这篇文章主要为大家详细介绍了javascript html获取系统当前时间,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • 简单实现js选项卡切换效果

    简单实现js选项卡切换效果

    这篇文章主要为大家介绍了简单实现js选项卡切换效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • 基于javascript实现tab切换特效

    基于javascript实现tab切换特效

    这篇文章主要介绍了基于javascript实现tab切换特效的相关资料,具有一定的参考价值,需要的朋友可以参考下
    2016-03-03
  • javascritp添加url参数将参数加入到url中

    javascritp添加url参数将参数加入到url中

    javascritp添加url参数方法,将参数加入到url中,如果原来url中有则覆盖,下面是示例代码,感兴趣的朋友可以参考下
    2014-09-09
  • js代码判断是否处于微信浏览器内两种方式

    js代码判断是否处于微信浏览器内两种方式

    微信内置浏览器屏蔽了下载链接,如果用户是用微信内置浏览器打开的,则提示用户换一个浏览器打开页面,那么该如何判断用户是否是用微信浏览器呢?这篇文章主要给大家介绍了关于js代码判断是否处于微信浏览器内的两种方式,需要的朋友可以参考下
    2023-10-10
  • 微信小程序之分享页面如何返回首页的示例

    微信小程序之分享页面如何返回首页的示例

    这篇文章主要介绍了微信小程序之分享页面如何返回首页的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03

最新评论