当前位置:首页 > VUE

vue实现select筛选功能

2026-01-21 18:13:31VUE

基础实现

使用Vue的v-model绑定select选中的值,结合v-for渲染选项列表。示例代码:

<template>
  <select v-model="selectedOption">
    <option 
      v-for="option in options" 
      :key="option.value" 
      :value="option.value"
    >
      {{ option.label }}
    </option>
  </select>
</template>

<script>
export default {
  data() {
    return {
      selectedOption: '',
      options: [
        { value: '1', label: '选项1' },
        { value: '2', label: '选项2' }
      ]
    }
  }
}
</script>

动态筛选功能

结合计算属性实现动态筛选。当选项数据来源于API或需要过滤时:

<template>
  <select v-model="selectedCategory">
    <option value="">全部</option>
    <option 
      v-for="cat in filteredCategories" 
      :key="cat.id" 
      :value="cat.id"
    >
      {{ cat.name }}
    </option>
  </select>
</template>

<script>
export default {
  data() {
    return {
      selectedCategory: '',
      allCategories: [
        { id: 1, name: '电子产品' },
        { id: 2, name: '家居用品' }
      ]
    }
  },
  computed: {
    filteredCategories() {
      return this.allCategories.filter(
        cat => cat.name.includes(this.searchText)
      )
    }
  }
}
</script>

多级联动筛选

实现省市区三级联动等复杂筛选:

<template>
  <select v-model="province" @change="loadCities">
    <option v-for="p in provinces" :value="p.id">{{ p.name }}</option>
  </select>

  <select v-model="city" :disabled="!province">
    <option v-for="c in cities" :value="c.id">{{ c.name }}</option>
  </select>
</template>

<script>
export default {
  data() {
    return {
      province: null,
      city: null,
      provinces: [],
      cities: []
    }
  },
  methods: {
    async loadCities() {
      this.cities = await fetchCities(this.province)
    }
  }
}
</script>

使用第三方组件

对于更复杂的需求,可以使用如Element UIel-select组件:

<template>
  <el-select 
    v-model="selectedTags" 
    multiple
    filterable
    placeholder="请选择标签"
  >
    <el-option
      v-for="tag in tags"
      :key="tag.value"
      :label="tag.label"
      :value="tag.value"
    />
  </el-select>
</template>

样式定制

通过CSS自定义select样式:

vue实现select筛选功能

select {
  padding: 8px 12px;
  border: 1px solid #dcdfe6;
  border-radius: 4px;
  background-color: #fff;
}

select:focus {
  border-color: #409eff;
  outline: none;
}

注意事项

  • 移动端体验需考虑原生select的替代方案
  • 大量数据时建议添加虚拟滚动优化
  • 国际化场景需要处理多语言选项
  • 表单验证场景需配合vuelidate等验证库

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

相关文章

vue 实现递归

vue 实现递归

Vue 实现递归组件的方法 在 Vue 中实现递归组件通常用于处理树形结构数据,例如菜单、评论列表或文件目录。以下是实现递归组件的关键步骤: 定义递归组件 递归组件需要设置 name 属性,以便在模…

vue实现erp

vue实现erp

Vue实现ERP系统的关键步骤 技术选型与架构设计 采用Vue 3 + TypeScript构建前端,搭配Pinia状态管理,Element Plus或Ant Design Vue作为UI框架。后端可…

javascript实现vue

javascript实现vue

Vue.js 的基本实现 在 JavaScript 中实现 Vue.js 的核心功能,主要包括数据绑定、响应式系统和虚拟 DOM。以下是一个简化的实现示例。 数据响应式系统 通过 Object.de…

vue实现筛选

vue实现筛选

实现筛选功能的基本思路 在Vue中实现筛选功能通常需要结合数据绑定、计算属性和方法。筛选的核心逻辑是根据用户输入的条件过滤原始数据列表,并动态更新显示结果。 数据准备 定义一个数组存储原始数据,另一…

vue实现pwa

vue实现pwa

Vue 实现 PWA 的步骤 Vue 结合 PWA(Progressive Web App)可以创建离线可用的 Web 应用。以下是实现方法: 安装 Vue CLI 并创建项目 确保已安装 Vue…

vue实现反馈

vue实现反馈

Vue 实现反馈功能的方法 在 Vue 中实现反馈功能可以通过多种方式,包括弹窗提示、Toast 消息、表单提交等。以下是几种常见的实现方法。 弹窗反馈 使用 Vue 的组件化特性创建一个弹窗组件,…