【vue】Vue中的filter()用法


前言

这两天频繁处理数组,好多好多有用的用法记录一下。

上一次学习了map()有没有用到哇,今天记录并且带你们学习filter()😁😁


一、filter()是什么?

filter()也是一个常用的操作,用于把数组的某些元素的筛选,然后返回剩下的元素。和map()类似,filter()也接收一个数组。和map()不同的是,filter()把传入的数组中的集合依次筛选每个符合条件的集合,然后根据返回值是true还是false决定保留还是丢弃该元素。

二、使用

1.案例一:筛选数组中满足某条件的集合组成新数组

请求来的数据data(json):

data = [
{ id:1, name:'小馨', tel:'136****123', time:'2022-04-12', tag:'0',age:'20' },
{ id:2, name:'小航', tel:'136****456', time:'2022-04-14', tag:'1',age:'21' },
{ id:3, name:'大航', tel:'152****789', time:'2022-04-16', tag:'1',age:'22' }{ id:4, name:'小艺', tel:'158****987', time:'2022-04-14', tag:'0',age:'21' }]

需要筛选得到已经审核通过的人名单即 tag 为 1

//已审核数组okList
this.okList = this.data.filter(item => item.tag === '1')
console.log(this.okList)
/**
	[{ id:2, name:'小航', tel:'136****456', time:'2022-04-14', tag:'1',age:'21' },
	 { id:3, name:'大航', tel:'152****456', time:'2022-04-16', tag:'1',age:'22' }]
*/      

当然可以多加条件筛选⬇:
还是原来的data,选tag为0且年龄小于21的

//新数组newList
this.newList= this.data.filter(item =>{
    return item.tag=== '0' && item.age < '21'
})
console.log(this.newList)
//	[{ id:1, name:'小馨', tel:'136****123', time:'2022-04-12', tag:'0',age:'20' }]      

2.案例二:巧妙的去重

请求得数据data(json):

 data = ['小馨','小白','小张','小航','小馨','小航']

该处渲染发现有重复数据需要剔除

// 筛选后新数组为newData
this.newData = this.data.filter((item,index,self) => self.indexOf(item)===index)
console.log(this.newData)
// 控制台输出
// ['小馨', '小白', '小张', '小航']

总结

以上就是今天要讲的并且记录的filter(),本文仅仅简单介绍了filter()的使用,js提供了大量能使我们快速便捷地处理数据的函数和方法,还在等我去发掘😎。(细心的小伙伴可能看到上述三个方法中有两个用了ES6的新方式:箭头函数 ’ => ’ 非常的便捷,有没有发现)

  • 32
    点赞
  • 86
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Vue,我们可以使用过滤器来对数据进行格式化或处理。要在Vue项目创建全局过滤器,可以在main.js文件注册全局过滤器,并且必须放在Vue实例创建之前。然后可以在各个组件使用这个全局过滤器。具体的步骤如下: 1. 在main.js文件注册全局过滤器。例如,我们可以创建一个名为"filter1"的全局过滤器: Vue.filter('filter1', function(value) { return value.charAt(0).toUpperCase() + value.slice(1); }); 2. 在Vue组件使用过滤器。在模板通过管道符"|"将数据绑定到过滤器上。例如,我们可以使用"filter1"过滤器对message进行处理: <div>{{ message | filter1 }}</div> 3. 如果需要依次使用多个过滤器,可以在模板用管道符连接它们。每个过滤器的参数为上一个过滤器返回的结果。例如,我们可以使用"filter1"和"filter2"两个过滤器对message进行处理: <div>{{ message | filter1 | filter2 }}</div> 另外,你还可以在组件内部定义局部过滤器。局部过滤器只能在当前组件使用,适用于处理数据显示的样式,不会改变原数据。例如,你可以在组件的filters选项定义过滤器,并在模板使用它们: ``` <template> <div> <ul> <li v-for="item in list">{{ item.id | filterAdd1 | filterAdd2 }}</li> </ul> </div> </template> <script> export default { data() { return { list: [ { "id": 0, "title": "11111", "cont": "111111" }, { "id": 1, "title": "22222", "cont": "111111" }, { "id": 2, "title": "33333", "cont": "111111" }, { "id": 3, "title": "44444", "cont": "111111" }, ] } }, filters: { filterAdd1(item) { return item + 10; }, filterAdd2(item) { return '$' + item; } }, methods: { }, mounted() { } } </script> ``` 这样,我们就可以在模板使用filterAdd1和filterAdd2两个过滤器来处理数据了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue过滤器filter的使用](https://blog.csdn.net/Hello_MrShu/article/details/127363940)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [vue filter的四种用法](https://blog.csdn.net/qappleh/article/details/89639948)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值