news 2026/5/26 9:03:36

前端与数据库交互

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端与数据库交互

1. 前端角色:发起请求和处理响应

前端主要负责:

  • 收集用户输入数据

  • 通过HTTP请求调用后端API

  • 处理响应并更新UI

2. 基础前端代码示例(使用Fetch API)

// API服务模块 class ApiService { constructor(baseURL) { this.baseURL = baseURL; } // 查询数据 async getItems() { try { const response = await fetch(`${this.baseURL}/api/items`); if (!response.ok) throw new Error('获取数据失败'); return await response.json(); } catch (error) { console.error('获取数据出错:', error); throw error; } } // 添加数据 async addItem(itemData) { try { const response = await fetch(`${this.baseURL}/api/items`, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify(itemData) }); if (!response.ok) throw new Error('添加失败'); return await response.json(); } catch (error) { console.error('添加数据出错:', error); throw error; } } // 更新数据 async updateItem(id, updateData) { try { const response = await fetch(`${this.baseURL}/api/items/${id}`, { method: 'PUT', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify(updateData) }); if (!response.ok) throw new Error('更新失败'); return await response.json(); } catch (error) { console.error('更新数据出错:', error); throw error; } } // 删除数据 async deleteItem(id) { try { const response = await fetch(`${this.baseURL}/api/items/${id}`, { method: 'DELETE' }); if (!response.ok) throw new Error('删除失败'); return true; } catch (error) { console.error('删除数据出错:', error); throw error; } } } // 使用示例 const api = new ApiService('https://your-backend.com'); // 获取并显示数据 async function loadAndDisplayItems() { const items = await api.getItems(); // 更新UI显示数据 } // 添加新项目 async function handleAddItem() { const newItem = { name: document.getElementById('itemName').value, description: document.getElementById('itemDesc').value }; await api.addItem(newItem); await loadAndDisplayItems(); // 刷新数据 }

后端实现示例(Node.js + Express + MySQL)

了解后端如何实现可以帮助前端开发者更好地协作:

// 后端API示例 const express = require('express'); const mysql = require('mysql2/promise'); require('dotenv').config(); const app = express(); app.use(express.json()); // 创建数据库连接池(生产环境使用环境变量) const pool = mysql.createPool({ host: process.env.DB_HOST, user: process.env.DB_USER, password: process.env.DB_PASSWORD, database: process.env.DB_NAME, waitForConnections: true, connectionLimit: 10 }); // 获取所有项目 app.get('/api/items', async (req, res) => { try { const [rows] = await pool.execute('SELECT * FROM items'); res.json(rows); } catch (error) { console.error('数据库查询错误:', error); res.status(500).json({ error: '服务器内部错误' }); } }); // 添加新项目 app.post('/api/items', async (req, res) => { try { const { name, description } = req.body; // 数据验证 if (!name || !description) { return res.status(400).json({ error: '缺少必要字段' }); } const [result] = await pool.execute( 'INSERT INTO items (name, description) VALUES (?, ?)', [name, description] ); res.status(201).json({ id: result.insertId, name, description }); } catch (error) { console.error('数据库插入错误:', error); res.status(500).json({ error: '服务器内部错误' }); } }); // 更新项目 app.put('/api/items/:id', async (req, res) => { // ... 类似实现 }); // 删除项目 app.delete('/api/items/:id', async (req, res) => { // ... 类似实现 }); app.listen(3000, () => { console.log('服务器运行在 http://localhost:3000'); });

现代前端数据管理方案

1. 使用状态管理库

// 以React + TanStack Query为例 import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query'; function ItemList() { const queryClient = useQueryClient(); // 获取数据 const { data: items, isLoading } = useQuery({ queryKey: ['items'], queryFn: () => fetch('/api/items').then(res => res.json()) }); // 添加数据 const addMutation = useMutation({ mutationFn: (newItem) => fetch('/api/items', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(newItem) }).then(res => res.json()), onSuccess: () => { queryClient.invalidateQueries(['items']); // 刷新数据 } }); // 类似地实现更新和删除... }

2. 使用专门的HTTP客户端

  • Axios: 功能强大的HTTP客户端

  • SWR: React专用的数据获取库

  • RTK Query: Redux Toolkit的数据获取解决方案

实际项目中的最佳实践

1. 统一错误处理

// 错误处理中间件 const handleApiError = async (response) => { if (!response.ok) { const error = await response.json().catch(() => ({})); throw new Error(error.message || `HTTP错误: ${response.status}`); } return response.json(); }; // 使用示例 fetch('/api/items') .then(handleApiError) .then(data => console.log(data)) .catch(error => showErrorToast(error.message));

2. 请求拦截器(添加认证等)

// Axios示例 axios.interceptors.request.use(config => { const token = localStorage.getItem('auth_token'); if (token) { config.headers.Authorization = `Bearer ${token}`; } return config; }); // 响应拦截器处理常见错误 axios.interceptors.response.use( response => response, error => { if (error.response?.status === 401) { // 跳转到登录页 window.location.href = '/login'; } return Promise.reject(error); } );
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 5:38:43

Redis原理篇-Dict的rehash

** 不管是扩容还是收缩,必定会创建新的哈希表,导致哈希表的size和sizemask变化,而key的查询与sizemask有关。因此必须对哈希表中的每一个key重新计算索引,插入新的哈希表,这个过程称为rehash。过程是这样的&#xff1a…

作者头像 李华
网站建设 2026/5/25 5:28:13

计算机考研408【计算机网络】核心知识点总结

计算机网络作为考研408的重要组成部分,占总分约25分,由选择题和综合应用题构成。掌握计算机网络的基本概念、原理和方法是备考的关键 ,尤其要理解OSI参考模型与TCP/IP模型的对应关系,以及各层协议的工作原理。本文将系统梳理计算机…

作者头像 李华
网站建设 2026/5/26 5:17:21

vue基于Spring Boot的公务员考试交流平台的应用和研究_729q3563

目录具体实现截图项目介绍论文大纲核心代码部分展示项目运行指导结论源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作具体实现截图 本系统(程序源码数据库调试部署讲解)同时还支持java、ThinkPHP、Node.js、Spring B…

作者头像 李华
网站建设 2026/5/26 5:57:17

AI 写论文哪个软件最好?别再被 “伪智能” 糊弄!多数工具只凑功能,真正能从开题到查重闭环交付的,唯有虎贲等考 AI 这款 “靠谱学术搭子”

📚 论文季打开应用商店,“AI 一键写论文”“免费查重降重” 的工具铺天盖地,但用过就知道:多数是 “伪智能” 凑功能 —— 选题老套无创新、文献无法溯源、降重后语句不通,还要在选题工具、文献软件、查重平台间来回切…

作者头像 李华
网站建设 2026/5/26 5:55:47

vue基于Spring Boot的高校学习讲座推荐系统_kh370h5z

目录具体实现截图项目介绍论文大纲核心代码部分展示项目运行指导结论源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作具体实现截图 本系统(程序源码数据库调试部署讲解)同时还支持java、ThinkPHP、Node.js、Spring B…

作者头像 李华