当前位置:首页 > VUE

vue实现搜索城市

2026-01-19 08:00:10VUE

Vue 实现搜索城市功能

数据准备

在Vue组件中定义一个城市列表数组和一个搜索关键词变量。城市列表可以静态定义或通过API动态获取。

data() {
  return {
    cities: ['北京', '上海', '广州', '深圳', '杭州', '成都', '重庆', '武汉'],
    searchQuery: ''
  }
}

模板部分

创建一个输入框用于输入搜索关键词,并显示过滤后的城市列表。

<template>
  <div>
    <input v-model="searchQuery" placeholder="搜索城市">
    <ul>
      <li v-for="city in filteredCities" :key="city">
        {{ city }}
      </li>
    </ul>
  </div>
</template>

计算属性

使用计算属性实现城市搜索过滤逻辑,根据输入的关键词匹配城市名称。

computed: {
  filteredCities() {
    return this.cities.filter(city => {
      return city.toLowerCase().includes(this.searchQuery.toLowerCase())
    })
  }
}

使用API获取城市数据

如果需要从后端获取城市数据,可以在created或mounted钩子中调用API。

created() {
  fetch('https://api.example.com/cities')
    .then(response => response.json())
    .then(data => {
      this.cities = data
    })
}

添加防抖优化

对于频繁的输入操作,可以添加防抖函数优化性能。

methods: {
  debounceSearch: _.debounce(function() {
    this.filteredCities = this.cities.filter(city => {
      return city.toLowerCase().includes(this.searchQuery.toLowerCase())
    })
  }, 300)
}

样式美化

为搜索框和列表添加基本样式,提升用户体验。

vue实现搜索城市

input {
  padding: 8px;
  width: 200px;
  margin-bottom: 10px;
}
ul {
  list-style: none;
  padding: 0;
}
li {
  padding: 5px;
  cursor: pointer;
}
li:hover {
  background-color: #f0f0f0;
}

标签: 城市vue
分享给朋友:

相关文章

vue实现选择本地文件

vue实现选择本地文件

实现文件选择功能 在Vue中实现本地文件选择可以通过HTML原生的<input type="file">元素实现。创建一个基本的文件选择组件: <template> &l…

vue实现轮询

vue实现轮询

实现轮询的基本方法 在Vue中实现轮询可以通过setInterval或setTimeout配合递归调用完成。轮询通常用于定期向服务器请求数据更新。 使用setInterval的简单示例: data…

vue实现图库

vue实现图库

Vue 实现图库的基本方法 使用 Vue 实现图库功能可以通过多种方式完成,以下是一些常见的方法和实现步骤。 使用 Vue 和第三方库(如 Vue Gallery) 安装 vue-gallery 或…

vue实现盖章

vue实现盖章

Vue 实现盖章功能 在Vue中实现盖章功能通常涉及前端UI交互,通过Canvas或SVG绘制印章,并允许用户拖拽或点击放置印章。以下是具体实现方法: 使用Canvas绘制印章 通过HTML5的Ca…

vue实现popup

vue实现popup

Vue 实现 Popup 弹窗 使用 Vue 原生组件 创建一个基本的 Vue 组件作为弹窗,通过 v-if 或 v-show 控制显示隐藏。 <template> <div&…

vue实现布局

vue实现布局

Vue 实现布局方法 Vue 提供了多种方式实现页面布局,可以通过组件化、CSS 框架或自定义样式完成。以下是几种常见方法: 使用 CSS Flexbox 或 Grid 通过 Vue 单文件组件结合…