Vue移除对象中的空参数,使用lodash移除对象中的空参数

1. 引言

在一些api参数加密场景中,经常会遇到将请求参数去除值为空的参数并排序的情况,所以这里记录一下如何在vue中使用lodash去除对象中的空参数,比如:null,""这种都被视作空参数。

2. lodash中的pickBy方法介绍

实现移除对象中的空参数,主要是使用了lodash中的pickBy方法,其在lodash官方文档中的解释如下:

_.pickBy(object, [predicate=_.identity])

创建一个对象,这个对象组成为从 object 中经 predicate 判断为真值的属性。 predicate调用2个参数:(value, key)

添加版本:Lodash 4.0.0

参数:

  1. object (Object): 来源对象。
  2. [predicate=_.identity] (Function): 调用每一个属性的函数。

返回:

        (Object): 返回新对象。

例子:

var object = { 'a': 1, 'b': '2', 'c': 3 };
 
_.pickBy(object, _.isNumber);
// => { 'a': 1, 'c': 3 }

3. 原理解析

        lodash的_.pickBy函数的作用是,将一个对象(第一个参数object)使用predicate(第二个参数)判断为真值,并创建一个新的对象返回。其中,predicate的缺省值是_.identity。

        lodash中的_.identity函数的作用是返回首个提供的参数,比如_.identify(object) 那么返回的结果就是object对象。

        但是我们如果向_.identity函数传入类似null或''(空字符串)这样的值呢?

if (_.identity(null)){
    console.log('test')
}

        显然,实际执行的是如下代码:

if (null){
    console.log('test')
}

        类似null、''、undefined、0、[]、{}这些值,用于if条件时,均会被视为false处理。

        使用它作为pickBy的第二个参数,那么就会对对象中的每一个参数进行判断,当值可以被视为false时,他会被从原对象中剔除,也就达到了我们过滤对象中的空参数的目的。

4. 如何实现过滤对象中的空参数

其中pickBy方法的第二个参数默认为_.identity,所以我们这里直接省略,默认使用缺省值,直接按如下方法使用即可达到我们去除空参数的目的:

const yourObject = {
    name: '',
    phone: '123456'
}
const params = _.pickBy({...yourObject})
console.log(params)
// => { phone: '123456' }

可以看到使用console.log打印params参数,控制台打印出的结果显示不包含name属性,实现了去除对象中的空参数。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无枫丶

谢谢老板!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值