实现一个全栈模糊搜索匹配的功能

提供一个全栈实现的方案,包括 Vue 3 前端、Express 后端和 MySQL 数据库的分类模糊搜索功能。让我们逐步来看:

1. 数据库设计 (MySQL)

首先,我们需要一个存储分类的表:

sql 复制代码
CREATE TABLE categories (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(255) NOT NULL,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

-- 插入一些示例数据
INSERT INTO categories (name) VALUES 
('Electronics'), ('Books'), ('Clothing'), ('Home & Garden'), ('Sports');

2. 后端实现 (Express)

安装必要的包

bash 复制代码
npm install express mysql2

创建数据库连接

javascript 复制代码
// db.js
const mysql = require('mysql2/promise');

const pool = mysql.createPool({
  host: 'localhost',
  user: 'your_username',
  password: 'your_password',
  database: 'your_database',
  waitForConnections: true,
  connectionLimit: 10,
  queueLimit: 0
});

module.exports = pool;

实现 Express 路由

javascript 复制代码
// app.js
const express = require('express');
const db = require('./db');
const app = express();

app.use(express.json());

app.get('/api/categories/search', async (req, res) => {
  try {
    const { query } = req.query;
    const [rows] = await db.query(
      'SELECT * FROM categories WHERE name LIKE ?',
      [`%${query}%`]
    );
    res.json(rows);
  } catch (error) {
    console.error(error);
    res.status(500).json({ error: 'Internal server error' });
  }
});

const PORT = process.env.PORT || 3000;
app.listen(PORT, () => console.log(`Server running on port ${PORT}`));

3. 前端实现 (Vue 3)

创建一个新的 Vue 3 组件

vue 复制代码
<!-- CategorySearch.vue -->
<template>
  <div>
    <input 
      v-model="searchQuery" 
      @input="searchCategories" 
      placeholder="Search categories..."
    />
    <ul>
      <li v-for="category in categories" :key="category.id">
        {{ category.name }}
      </li>
    </ul>
  </div>
</template>

<script>
import { ref } from 'vue';
import axios from 'axios';

export default {
  setup() {
    const searchQuery = ref('');
    const categories = ref([]);

    const searchCategories = async () => {
      if (searchQuery.value.length > 0) {
        try {
          const response = await axios.get(`/api/categories/search?query=${searchQuery.value}`);
          categories.value = response.data;
        } catch (error) {
          console.error('Error fetching categories:', error);
        }
      } else {
        categories.value = [];
      }
    };

    return {
      searchQuery,
      categories,
      searchCategories
    };
  }
};
</script>

在主应用中使用组件

vue 复制代码
<!-- App.vue -->
<template>
  <div id="app">
    <h1>Category Search</h1>
    <CategorySearch />
  </div>
</template>

<script>
import CategorySearch from './components/CategorySearch.vue';

export default {
  name: 'App',
  components: {
    CategorySearch
  }
};
</script>

4. 优化建议

  1. 防抖:在前端实现防抖,避免频繁的 API 调用。
  2. 缓存:考虑在后端实现缓存机制,减少数据库查询。
  3. 分页:如果分类数量很大,考虑实现分页功能。
  4. 索引:在 MySQL 的 categories 表的 name 列上添加索引,提高查询性能。
sql 复制代码
CREATE INDEX idx_category_name ON categories(name);
  1. 安全性:确保对用户输入进行适当的验证和清理,防止 SQL 注入攻击。

这个实现提供了一个基本的全栈分类模糊搜索功能。您可以根据具体需求进行进一步的定制和优化。如果您有任何问题或需要更详细的解释,请随时告诉我。

注意,MySQL 的 LIKE 操作符默认是不区分大小写的。

相关推荐
半个烧饼不加肉1 天前
JS 底层探究-- 普通函数和构造函数
开发语言·javascript·原型模式
Java.熵减码农1 天前
Hermes Agent 安装踩坑记录:DNS 解析失败 & Node.js 幽灵文件冲突
node.js·ai编程·hermes
meilindehuzi_a1 天前
透视 V8 底部:从物理内存到函数式哲学,重新解构 JavaScript 数组
开发语言·javascript·ecmascript
接着奏乐接着舞。1 天前
Node.js 掌握度 20 题自测水平
node.js
粉末的沉淀1 天前
vue:Vite项目中高效管理纯色SVG图标的方案
前端·javascript·vue.js
FlyWIHTSKY1 天前
JavaScript 和 TypeScript 分别是什么,可以相互写吗
javascript·ubuntu·typescript
YHHLAI1 天前
JavaScript 数据结构精讲:数组底层与实战避坑
开发语言·javascript·数据结构
moMo1 天前
Promise 的本质:不是异步处理,而是流程控制
javascript
dotnet901 天前
PDF 页面尺寸上限是 14400。iText 直接加载成功的大图可能超过这个限制,需要在 setPageSize 之前等比缩放。
前端·javascript·html
threelab1 天前
Three.js 几何图形变换 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器