当前位置:首页 > VUE

vue实现筛选

2026-03-07 09:31:47VUE

Vue实现筛选功能的方法

使用计算属性实现筛选

计算属性是Vue中实现数据筛选的高效方式,能够根据依赖的数据自动更新筛选结果。

<template>
  <div>
    <input v-model="searchQuery" placeholder="搜索...">
    <ul>
      <li v-for="item in filteredItems" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      searchQuery: '',
      items: [
        { id: 1, name: '苹果' },
        { id: 2, name: '香蕉' },
        { id: 3, name: '橙子' }
      ]
    }
  },
  computed: {
    filteredItems() {
      return this.items.filter(item => 
        item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
      )
    }
  }
}
</script>

使用watch实现复杂筛选

当筛选逻辑较复杂或需要异步操作时,可以使用watch配合methods实现。

<script>
export default {
  data() {
    return {
      searchQuery: '',
      items: [],
      filteredItems: []
    }
  },
  watch: {
    searchQuery(newVal) {
      this.filterItems(newVal)
    }
  },
  methods: {
    filterItems(query) {
      this.filteredItems = this.items.filter(item =>
        item.name.toLowerCase().includes(query.toLowerCase())
      )
    }
  },
  created() {
    // 模拟异步获取数据
    setTimeout(() => {
      this.items = [
        { id: 1, name: '苹果' },
        { id: 2, name: '香蕉' },
        { id: 3, name: '橙子' }
      ]
      this.filteredItems = [...this.items]
    }, 500)
  }
}
</script>

多条件筛选实现

对于需要多个筛选条件的场景,可以扩展筛选逻辑。

<template>
  <div>
    <input v-model="filters.name" placeholder="名称">
    <input v-model="filters.category" placeholder="类别">
    <ul>
      <li v-for="item in filteredItems" :key="item.id">
        {{ item.name }} - {{ item.category }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      filters: {
        name: '',
        category: ''
      },
      items: [
        { id: 1, name: '苹果', category: '水果' },
        { id: 2, name: '胡萝卜', category: '蔬菜' },
        { id: 3, name: '香蕉', category: '水果' }
      ]
    }
  },
  computed: {
    filteredItems() {
      return this.items.filter(item => {
        const nameMatch = item.name.toLowerCase().includes(
          this.filters.name.toLowerCase()
        )
        const categoryMatch = item.category.toLowerCase().includes(
          this.filters.category.toLowerCase()
        )
        return nameMatch && categoryMatch
      })
    }
  }
}
</script>

使用第三方库实现高级筛选

对于更复杂的筛选需求,可以考虑使用lodash等工具库。

import _ from 'lodash'

export default {
  data() {
    return {
      searchQuery: '',
      items: [
        /* 数据数组 */
      ]
    }
  },
  computed: {
    filteredItems() {
      return _.filter(this.items, item => 
        _.includes(_.toLower(item.name), _.toLower(this.searchQuery))
      )
    }
  }
}

服务器端筛选实现

当数据量较大时,可以将筛选逻辑放到服务器端。

vue实现筛选

methods: {
  async fetchFilteredData() {
    try {
      const response = await axios.get('/api/items', {
        params: {
          search: this.searchQuery
        }
      })
      this.filteredItems = response.data
    } catch (error) {
      console.error('筛选数据获取失败:', error)
    }
  }
},
watch: {
  searchQuery: _.debounce(function() {
    this.fetchFilteredData()
  }, 500)
}

以上方法涵盖了从简单到复杂的各种筛选场景,可以根据实际需求选择适合的实现方式。计算属性适合大多数客户端筛选场景,而服务器端筛选则适合大数据量情况。

标签: vue
分享给朋友:

相关文章

vue实现微博印象

vue实现微博印象

实现微博印象功能的核心思路 微博印象功能通常指用户发布微博后,系统自动分析文本内容并提取关键词或标签,以可视化形式展示。Vue实现该功能需要结合文本分析、关键词提取和前端渲染技术。 文本分析与关键词…

vue实现功能

vue实现功能

Vue 功能实现方法 Vue.js 是一个渐进式 JavaScript 框架,用于构建用户界面。以下是实现常见功能的几种方法: 数据绑定与响应式更新 在 Vue 中,数据绑定通过 v-model…

vue实现管道

vue实现管道

Vue 中实现管道(Pipe)功能 在 Vue 中可以通过过滤器(Filters)或计算属性(Computed Properties)实现类似管道的功能,将数据经过多个处理步骤后输出。 使用过滤器(…

分页实现vue

分页实现vue

分页实现(Vue) 在Vue中实现分页功能通常需要结合前端分页逻辑和后端API支持。以下是两种常见的实现方式: 前端分页实现 适用于数据量较小的情况,直接在客户端完成分页逻辑。 <templ…

vue插件实现

vue插件实现

Vue 插件实现方法 Vue 插件是一种向 Vue 应用程序添加全局功能的机制。插件可以包含全局指令、过滤器、混入、实例方法等。 插件的基本结构 一个 Vue 插件通常是一个对象或函数,需要暴露一个…

甘特图vue实现

甘特图vue实现

甘特图 Vue 实现方法 使用开源库 vue-ganttastic 安装依赖: npm install vue-ganttastic 基础实现代码: <template> <…