IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue移除对象中的空参数,使用lodash移除对象中的空参数 -> 正文阅读

[JavaScript知识库]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属性,实现了去除对象中的空参数。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:16:14  更:2022-04-01 23:17:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 5:49:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码