当前位置:首页 > VUE

vue实现筛选框

2026-01-17 22:47:14VUE

实现筛选框的基本思路

在Vue中实现筛选框通常涉及数据绑定、事件处理和列表渲染。筛选框可以基于用户输入动态过滤数据列表,提升交互体验。

基础实现示例

创建一个包含输入框和列表的组件,通过v-model绑定输入值,利用计算属性实时过滤数据:

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实现筛选框

computed: {
  filteredItems() {
    return this.items.filter(item => {
      const matchesName = item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
      const matchesCategory = item.category.toLowerCase().includes(this.categoryQuery.toLowerCase())
      return matchesName && matchesCategory
    })
  }
}

使用第三方库增强功能

对于复杂筛选需求,可借助lodash的防抖功能优化性能:

import { debounce } from 'lodash'

export default {
  methods: {
    handleSearch: debounce(function() {
      // 筛选逻辑
    }, 300)
  }
}

样式优化建议

为筛选框添加基础样式提升用户体验:

input {
  padding: 8px;
  border: 1px solid #ddd;
  border-radius: 4px;
  width: 200px;
}
ul {
  list-style: none;
  padding: 0;
}
li {
  padding: 8px;
  border-bottom: 1px solid #eee;
}

注意事项

  • 对于大数据量列表,建议添加虚拟滚动优化性能
  • 敏感字符输入需做转义处理防止XSS攻击
  • 移动端需确保输入框适配虚拟键盘

标签: vue
分享给朋友:

相关文章

vue的艾特功能实现

vue的艾特功能实现

Vue 的 @ 功能实现 在 Vue 中实现类似社交平台的 @ 功能,通常涉及输入框的监听、用户匹配和选择插入。以下是具体实现方法: 监听输入框内容 使用 v-model 绑定输入框内容,并通过 @…

vue实现字母添加排序

vue实现字母添加排序

实现字母添加排序的方法 在Vue中实现字母添加排序功能,可以通过以下步骤完成: 创建Vue实例并定义数据 new Vue({ el: '#app', data: { letters…

vue实现密码框的包

vue实现密码框的包

Vue 密码框实现方案 在 Vue 中实现密码框功能,可以通过原生 HTML 结合 Vue 指令或使用第三方组件库完成。以下是几种常见方案: 原生 HTML + Vue 双向绑定 <t…

vue grid实现

vue grid实现

Vue Grid 实现方法 在 Vue 中实现网格布局可以通过多种方式完成,包括使用原生 CSS Grid、第三方组件库或自定义组件。以下是几种常见方法: 使用原生 CSS Grid 通过 Vue…

vue路由实现

vue路由实现

Vue 路由实现 Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用(SPA)。以下是 Vue Router 的基本实现步骤和核心功能。 安装 Vue Router 通过…

vue实现cs

vue实现cs

Vue 实现 CS(Client-Side)渲染的常见方法 Vue.js 是一个用于构建用户界面的渐进式框架,默认采用客户端渲染(CSR)。以下是几种常见的实现方式: 使用 Vue CLI 创建项目…