当前位置:首页 > VUE

vue表单实现搜索

2026-02-09 13:18:22VUE

Vue 表单搜索实现方法

基础表单绑定

使用 v-model 实现双向数据绑定,监听用户输入。示例代码:

<template>
  <input v-model="searchQuery" placeholder="输入搜索关键词">
</template>

<script>
export default {
  data() {
    return {
      searchQuery: ''
    }
  }
}
</script>

实时搜索功能

结合 watchcomputed 属性实现实时响应:

watch: {
  searchQuery(newVal) {
    this.debouncedSearch(newVal)
  }
},
methods: {
  debouncedSearch: _.debounce(function(query) {
    this.fetchResults(query)
  }, 500)
}

搜索结果展示

使用 v-for 渲染过滤后的结果:

vue表单实现搜索

<ul>
  <li v-for="item in filteredItems" :key="item.id">
    {{ item.name }}
  </li>
</ul>

服务端搜索集成

通过 axios 发送请求到后端 API:

methods: {
  fetchResults(query) {
    axios.get('/api/search', { params: { q: query } })
      .then(response => {
        this.results = response.data
      })
  }
}

表单验证

添加基础输入验证:

vue表单实现搜索

data() {
  return {
    searchQuery: '',
    errors: []
  }
},
methods: {
  validateSearch() {
    this.errors = []
    if (this.searchQuery.length < 2) {
      this.errors.push('关键词至少需要2个字符')
    }
  }
}

高级功能实现

  1. 多条件筛选:

    computed: {
    filteredItems() {
     return this.items.filter(item => {
       return (
         item.name.includes(this.searchQuery) ||
         item.description.includes(this.searchQuery)
       )
     })
    }
    }
  2. 搜索历史记录:

    methods: {
    saveToHistory(query) {
     if (!this.searchHistory.includes(query)) {
       this.searchHistory.unshift(query)
     }
    }
    }

标签: 表单vue
分享给朋友:

相关文章

vue 表格实现

vue 表格实现

Vue 表格实现方法 在 Vue 中实现表格功能可以通过多种方式完成,以下介绍几种常见的方法: 使用原生 HTML 表格 最简单的表格可以通过 Vue 模板中的原生 HTML 表格元素实现: &l…

vue实现单页面

vue实现单页面

Vue 实现单页面应用(SPA) Vue.js 是一个渐进式框架,非常适合构建单页面应用(SPA)。SPA 的核心特点是整个应用只有一个 HTML 页面,通过动态加载内容实现页面切换,无需重新加载整个…

vue实现多级组件

vue实现多级组件

实现多级组件的基本结构 在Vue中实现多级组件通常涉及父子组件嵌套,通过props向下传递数据,通过$emit向上传递事件。多级组件的核心是递归或动态组件渲染。 <!-- 父组件 Parent…

vue实现主题

vue实现主题

Vue 实现主题的方法 使用 CSS 变量动态切换主题 定义全局 CSS 变量,通过修改这些变量实现主题切换。在 Vue 的根组件或全局样式中定义变量: :root { --primary-co…

vue 实现tabs

vue 实现tabs

Vue 实现 Tabs 组件的方法 使用动态组件和 v-for 在 Vue 中实现 Tabs 可以通过动态组件和 v-for 指令结合完成。定义一个 tabs 数组,包含每个标签的标题和对应的组件。…

vue 实现级联

vue 实现级联

Vue 实现级联选择器 级联选择器(Cascader)常用于省市区选择、分类选择等场景。Vue 中可以通过 Element UI、Ant Design Vue 等 UI 库实现,也可以手动封装。 使…