前端使用js实现多个种类筛选

文章目录

概要

实现类似以下图片的效果

整体架构流程

1.在HTML模板中创建一个容器,用于放置筛选组件

<view>
  <view class="filter-container">
    <view class="filter-item" v-for="(item, index) in filters" :key="index">
      <text>{{ item.name }}</text>
      <view class="filter-values">
        <view class="filter-value" 
          v-for="(value, index) in item.values" 
          :key="index"
          @click="handleFilterClick(item.id, value.id)">
          {{ value.name }}
        </view>
      </view>
    </view>
  </view>
</view>

2.在vue数据对象中定义筛选条件

data() {
  return {
    filters: [
      {
        id: 1,
        name: '选择类型',
        values: [
          { id: 1, name: '全部' },
          { id: 2, name: '盒子' },
          { id: 3, name: 'x86' },
        ],
      },
      {
        id: 2,
        name: '选择状态',
        values: [
          { id: 1, name: '全部' },
          { id: 2, name: '在线' },
          { id: 3, name: '离线' },
        ],
      },
    ],
    selectedFilters: {},
  };
}

3.处理筛选点击事件的方法

methods: {
  handleFilterClick(filterId, valueId) {
    this.selectedFilters = {
      ...this.selectedFilters,
      [filterId]: valueId,
    };
    this.fetchData();
  },
},

4.实现获取数据的方法(异步请求)

methods: {
  async fetchData() {
    // 在此处发送异步请求,并根据选中的筛选条件过滤数据
    // 例如,使用 `uni.request` 发送 HTTP 请求
    const response = await uni.request({
      url: '***/api/data',
      data: this.selectedFilters,
    });
    
    this.items = response.data.items;
  },
},

5.在created生命周期里初始化数据

created() {
  this.fetchData();
},

小结

以上展示了uniapp项目中实现多个种类的筛选,可根据具体需求,对代码进行相关调整和优化

  • 23
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,您的问题是关于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时的问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值