vue中优雅的实现前端列表多条件筛选

1、先上图:
在这里插入图片描述
2、搜索条件绑定的数据是:

filterForm:{
	schoolName:'',//输入的学校名称
	position:'',//选择的区域区域
	schoolLevel:"",//选择的学校办别
},
schoolList:[
	{schoolName:'青岛市实验高级中学',schoolLevel:"",position:'山东省青岛市城阳区硕阳路69号'},
	{schoolName:'山东省青岛第二中学',schoolLevel:"",position:'山东省青岛市崂山区松岭路70号'},
	{schoolName:'山东省青岛第一中学',schoolLevel:"",position:'山东省青岛市市南区单县路46号'},
	{schoolName:'山东省青岛第三十九中学',schoolLevel:"",position:'市南区登州路5号'},
	{schoolName:'山东省青岛第六中学',schoolLevel:"",position:'山东省青岛市黄岛区云台山路66号'},
	{schoolName:'山东省青岛第十九中学',schoolLevel:"",position:'山东省青岛市即墨区鳌山卫街道卫场路69号'},
	{schoolName:'青岛艺术学校',schoolLevel:"",position:'青岛市李沧区九水路176号'},
	{schoolName:'山东省青岛第九中学',schoolLevel:"",position:'山东省青岛市黄岛区七星河路559号'},
	{schoolName:'青岛电子学校',schoolLevel:"",position:'山东省青岛市市北区台东一路118号'}
],//其中schoolList是元数据
resull:[]//搜索结果,也是列表循环的数据

3、监听:

watch: {
	// 监听对象变化
	filterForm:{
		handler(val, oldVal){
			if(val){
				// 如果筛选条件全为空,查全部;否则按条件筛选
				var objIsEmpty = this.filterForm.schoolName == '' && this.filterForm.schoolLevel == '' && this.filterForm.position == ''
				if(objIsEmpty){
					this.result = this.schoolList
				} else {
					// /拿到有值的参数
					let tempFilter = {};
					for(var key in this.filterForm) {
						if(typeof(this.filterForm[key]) != "undefined" && typeof(this.filterForm[key]) != "null" && this.filterForm[key] != null && this.filterForm[key] != "") {
							tempFilter[key] = this.filterForm[key];
						}
					}
					// console.log(tempFilter,'输出tempFilter')
					this.result = this.schoolList.filter(
						//筛选
						(item) => {
							let flag = false;
							for(key in tempFilter) {
								console.log(key,'输出key')
									if(item[key].toString().indexOf(tempFilter[key].toString()) >= 0) {
										flag = true;
									} else {
                                        flag = false;
                                        break;
                                    }
                                }
                                if(flag) {
                                    return item;
                                }
                            }
                        );
                        console.log(this.result,'输出筛选结果')
                    }
                }
            },
            deep:true
        }
}
  • 7
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,您的问题是关于Vue.js实现前端列表条件筛选的问题,同时涉及Vue的key属性的重复问题。 对于实现前端列表条件筛选,一种常见的做法是使用计算属性来过滤列表数据。具体来说,可以定义一个包含各种筛选条件的data对象,然后在计算属性根据这些条件来过滤原始的列表数据。例如: ``` <template> <div> <label>关键字:</label> <input v-model="filter.keyword"> <label>状态:</label> <select v-model="filter.status"> <option value="">全部</option> <option value="1">已完成</option> <option value="0">未完成</option> </select> <ul> <li v-for="item in filteredList" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { data() { return { list: [ { id: 1, name: '任务1', status: 1 }, { id: 2, name: '任务2', status: 0 }, { id: 3, name: '任务3', status: 1 } ], filter: { keyword: '', status: '' } } }, computed: { filteredList() { return this.list.filter(item => { return item.name.indexOf(this.filter.keyword) !== -1 && (this.filter.status === '' || item.status.toString() === this.filter.status) }) } } } </script> ``` 在上面的代码,我们定义了一个包含列表数据和筛选条件的data对象,其filter对象包含了关键字和状态两个筛选条件。然后,在计算属性filteredList,我们使用filter函数来过滤原始列表数据,其关键字筛选使用了JavaScript的字符串indexOf方法,状态筛选则使用了三目运算符来判断是否需要进行状态筛选。 在这个例子,我们没有显式地使用key属性来指定每个列表项的唯一标识符。这是因为Vue.js默认会使用每个列表项的下标作为其key。然而,如果列表数据是动态的,那么可能会出现某些列表项的下标发生变化的情况,从而导致Vue.js无法正确地更新DOM。为了解决这个问题,我们可以显式地指定每个列表项的唯一标识符,例如使用item.id作为key。这样可以确保每个列表项的key始终唯一,从而避免出现更新DOM时的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值