当前位置:网站首页 > JavaScript开发 > 正文

JavaScript 递归遍历对象:过滤对象中为null/undefined/''/[]/{}的属性值

// 过滤对象中为null/undefined/''/[]/{}的属性值 function clearDeep(obj) { if (!obj || !typeof obj === 'object') return const keys = Object.keys(obj) for (var key of keys) { const val = obj[key] if ( typeof val === 'undefined' || ((typeof val === 'object' || typeof val === 'string') && !val) ) { // 如属性值为null或undefined或'',则将该属性删除 delete obj[key] } else if (typeof val === 'object') { // 属性值为对象,递归调用 clearDeep(obj[key]) if (Object.keys(obj[key]).length === 0) { // 如某属性的值为不包含任何属性的独享,则将该属性删除 delete obj[key] } } } } var obj3 = [ { 'a': 1, 'test': {} }, { 'b': '' }, { 'c': '', 'd': { 'e': null, 'f': undefined, 'g': 'test', 'h': [ { 'i': '', 'j': '哈哈哈', 'k': [] } ] } } ] clearDeep(obj3) console.log(obj3) 

到此这篇JavaScript 递归遍历对象:过滤对象中为null/undefined/''/[]/{}的属性值的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • JavaScript-对象扁平化:只保留最里层key2024-12-02 09:18:04
  • JavaScript封装检测是否为空(包括空字符串、空格、null,{},[])2024-12-02 09:18:04
  • JavaScript精确计算加减乘除2024-12-02 09:18:04
  • JavaScript好用地址2024-12-02 09:18:04
  • JavaScript根据对象的key重新排序2024-12-02 09:18:04
  • Javascript-every遍历数组 每一项均符合条件后执行相应操作2024-12-02 09:18:04
  • JavaScript 动态修改Objcet的属性值2024-12-02 09:18:04
  • JavaScript毫秒整数转化为时分秒2024-12-02 09:18:04
  • Javascript-filter遍历数组 返回符合条件的每一项2024-12-02 09:18:04
  • 一级用html+javascript打造公文一键排版系统4:一级标题排版二级用html+javascript打造公文一键排版系统4:一级标题排版示范空两格(一级用html+javascript打造公文一键排版系统4:一级标题排版二级用html+javascript打造公文一键排版系统4:一级标题排版三级用html+javascript打造公文一键排版系统4:一级标题排版前面空格2024-12-02 09:18:04
  • 全屏图片