当前位置:首页 > VUE

vue实现筛选功能

2026-02-17 08:56:59VUE

实现筛选功能的基本思路

在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>

使用方法实现动态筛选

当筛选逻辑需要参数或更复杂时,可以使用方法代替计算属性。

vue实现筛选功能

<template>
  <div>
    <input v-model="searchQuery" @input="filterItems">
    <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: '橙子' }
      ],
      filteredItems: []
    }
  },
  methods: {
    filterItems() {
      this.filteredItems = this.items.filter(item =>
        item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
      )
    }
  },
  mounted() {
    this.filterItems()
  }
}
</script>

多条件筛选实现

对于需要多个筛选条件的场景,可以结合多个输入控件和更复杂的筛选逻辑。

<template>
  <div>
    <input v-model="filters.name" placeholder="名称">
    <select v-model="filters.category">
      <option value="">所有分类</option>
      <option value="fruit">水果</option>
      <option value="vegetable">蔬菜</option>
    </select>
    <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: 'fruit' },
        { id: 2, name: '香蕉', category: 'fruit' },
        { id: 3, name: '胡萝卜', category: 'vegetable' }
      ]
    }
  },
  computed: {
    filteredItems() {
      return this.items.filter(item => {
        const nameMatch = item.name.toLowerCase().includes(
          this.filters.name.toLowerCase()
        )
        const categoryMatch = this.filters.category === '' || 
          item.category === this.filters.category
        return nameMatch && categoryMatch
      })
    }
  }
}
</script>

使用第三方库增强筛选功能

对于复杂筛选需求,可以考虑使用lodash等工具库提供的函数式编程方法。

vue实现筛选功能

import _ from 'lodash'

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

服务器端筛选实现

当数据量很大时,可以将筛选逻辑移到服务器端,通过API请求获取筛选结果。

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

<script>
import axios from 'axios'
import _ from 'lodash'

export default {
  data() {
    return {
      searchQuery: '',
      filteredItems: [],
      debouncedFilter: _.debounce(this.fetchFilteredItems, 500)
    }
  },
  methods: {
    fetchFilteredItems() {
      axios.get('/api/items', {
        params: {
          q: this.searchQuery
        }
      }).then(response => {
        this.filteredItems = response.data
      })
    }
  }
}
</script>

筛选性能优化技巧

对于大型列表,可以采用虚拟滚动、分页或防抖技术来优化性能。

export default {
  data() {
    return {
      searchQuery: '',
      items: [], // 大量数据
      currentPage: 1,
      itemsPerPage: 20
    }
  },
  computed: {
    filteredItems() {
      const start = (this.currentPage - 1) * this.itemsPerPage
      const end = start + this.itemsPerPage
      return this.items
        .filter(item => item.name.includes(this.searchQuery))
        .slice(start, end)
    }
  }
}

以上实现方式涵盖了Vue中筛选功能的常见场景,从基础实现到性能优化,可以根据具体需求选择合适的方法。

标签: 功能vue
分享给朋友:

相关文章

vue实现异步

vue实现异步

Vue 实现异步操作的常见方法 Vue 提供了多种方式来处理异步操作,包括数据获取、事件处理等场景。 使用 async/await 在 Vue 方法中可以直接使用 async/await 语法处理异…

vue 组件实现

vue 组件实现

Vue 组件实现方法 单文件组件 (SFC) 使用 .vue 文件格式,包含模板、脚本和样式三部分: <template> <div class="example">{{…

vue实现动画

vue实现动画

Vue 实现动画的方法 Vue 提供了多种方式来实现动画效果,包括内置的过渡系统、第三方动画库以及直接操作 CSS 或 JavaScript 动画。 使用 Vue 内置过渡系统 Vue 的 <…

vue实现fragment

vue实现fragment

Vue 实现 Fragment 的方法 在 Vue 中,Fragment 允许组件返回多个根节点而不需要包裹一个额外的 DOM 元素。以下是几种实现方式: 使用 Vue 3 的 <templa…

vue 实现hover

vue 实现hover

Vue 实现 Hover 效果的方法 在 Vue 中实现 hover 效果可以通过多种方式完成,以下是几种常见的方法: 使用 CSS 伪类 :hover 最简单的方式是直接使用 CSS 的 :hov…

vue实现spa

vue实现spa

Vue 实现 SPA(单页应用)的步骤 创建 Vue 项目 使用 Vue CLI 快速初始化一个 Vue 项目,确保安装了 Vue Router 作为路由管理工具。运行以下命令创建项目: vue c…