当前位置:首页 > 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 Router 是 Vue.js 官方的路由管理器,用于实现单页应用(SPA)的页面切换。以下是几种常见的内部路由切换方式: 使用 <router-lin…

vue无限菜单怎么实现

vue无限菜单怎么实现

实现 Vue 无限菜单的方法 递归组件实现嵌套菜单 使用 Vue 的递归组件特性可以轻松实现无限级嵌套菜单。通过组件调用自身的方式处理嵌套数据。 <template> <ul&…

vue cli 实现

vue cli 实现

Vue CLI 实现步骤 安装 Vue CLI 确保 Node.js 版本在 8.9 或以上。通过 npm 全局安装 Vue CLI: npm install -g @vue/cli 创建新项目 使…

vue滑块实现

vue滑块实现

Vue滑块实现方法 使用原生HTML5 range input Vue中可以绑定原生HTML5的range类型input元素实现基础滑块功能: <template> <div&…

vue实现settimeout

vue实现settimeout

在 Vue 中实现 setTimeout Vue 中可以通过 JavaScript 原生的 setTimeout 方法实现延时操作,但需要注意结合 Vue 的响应式特性和生命周期管理。以下是几种常见实…

vue实现spa

vue实现spa

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