5.1 如何使用 React/Vue 发起后端请求?用什么库?

面试官您好,在实际项目中我们通常使用 axiosfetch 或框架提供的封装库发起后端请求。


🔧 常用库对比:

框架适配优点
axios通用默认支持拦截器、取消请求、请求体转换
fetch通用原生支持但较原始,无拦截器
useSWRReact适合缓存和自动请求更新(推荐)
Vue ResourceVue 2 已弃用已被淘汰
@vueuse/coreVue 3配合 Composition API 很方便


🧩 示例:React 中使用 axios(Hooks + 拦截器)

import axios from 'axios';
import { useEffect, useState } from 'react';const api = axios.create({baseURL: '/api',timeout: 5000,
});export function useUserData() {const [data, setData] = useState(null);useEffect(() => {api.get('/user/info').then(res => setData(res.data));}, []);return data;
}

5.2 状态管理你用什么?Redux、Pinia、Zustand 等对比

状态管理选择要结合项目复杂度和框架生态,React 我常用 Zustand 或 Redux Toolkit,Vue 我用 Pinia。


🔍 状态管理库对比:

名称所属框架特点使用建议
Redux ToolkitReact官方推荐,类型安全,支持异步大型项目推荐
ZustandReact极简、无模板代码、Hook 风格中小型项目非常适合
RecoilReact原子化状态,更适合组件隔离场景组件粒度状态管理
VuexVue 2老牌方案,API 繁琐不推荐新项目使用
PiniaVue 3轻量、支持模块拆分、Composition APIVue 3 项目首选


示例:Zustand 创建用户状态(React)

import create from 'zustand';export const useUserStore = create(set => ({user: null,setUser: (data) => set({ user: data })
}));

示例:Pinia 创建用户状态(Vue)

import { defineStore } from 'pinia';export const useUserStore = defineStore('user', {state: () => ({ user: null }),actions: {setUser(data) {this.user = data;}}
});

5.3 如果一个接口很慢,你如何在 UI 上做友好的处理?

面试官我会从「用户感知」和「界面提示」两个维度入手优化体验:


⏳ 接口慢时的 UI 优化手段:

  1. 骨架屏:如加载用户卡片、文章列表的占位框架;

  2. loading Spinner:展示加载中状态,防止用户误操作;

  3. 请求超时提示:超过 X 秒提示“网络可能异常”;

  4. 请求缓存 / 懒加载:结合 SWR / React Query / keep-alive 优化重复加载;

  5. 预请求策略:页面还未进入前发起关键数据请求,提升首屏速度。


示例(React + Skeleton):

return isLoading ? <Skeleton count={5} /> : <UserList data={users} />;


5.4 如何处理请求节流、防抖?封装方式?

防抖与节流是优化高频请求的重要手段,尤其在搜索框、滚动加载等场景非常常见。


🔄 原理区别:

名称原理应用场景
防抖延迟执行,用户停止操作后触发搜索、输入提示
节流固定时间间隔执行一次滚动加载、按钮点击防重复


✅ Lodash 工具函数(实战推荐):

import { debounce, throttle } from 'lodash';const onSearch = debounce((val) => {fetchData(val);
}, 500);const onScroll = throttle(() => {loadMore();
}, 1000);

✅ 自定义封装 Hook(React)

function useDebounce(fn, delay) {const timer = useRef(null);return (...args) => {clearTimeout(timer.current);timer.current = setTimeout(() => fn(...args), delay);};
}

5.5 如何将分页、筛选、排序的参数传给后端?

这是常规表格 / 列表 API 设计问题,建议采用统一参数命名规范。


📌 传参结构建议:

GET /api/users?page=1&pageSize=10&sortBy=name&order=asc&status=active

参数描述
page当前页码
pageSize每页条数
sortBy排序字段
order排序方向(asc/desc)
filters状态、关键词等条件


✅ React 示例:

const [params, setParams] = useState({page: 1,pageSize: 10,sortBy: 'createdAt',order: 'desc',status: 'active'
});useEffect(() => {axios.get('/api/posts', { params });
}, [params]);

✅ Vue 示例(配合分页组件):

const params = reactive({page: 1,pageSize: 10,sortBy: 'createdAt',order: 'desc'
});watch(() => [params.page, params.pageSize], () => {fetchData(params);
});

✅ 总结

编号技术点核心亮点
5.1请求库选择axios 最通用、SWR 自动缓存、NestJS 中也支持 axios
5.2状态管理Vue 用 Pinia,React 建议 Zustand 或 Redux Toolkit
5.3UI 慢接口处理骨架屏、loading、预加载
5.4节流防抖封装lodash、React Hook、自定义封装
5.5分页筛选排序参数传递page、pageSize、sortBy、filters 一致性封装


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/907948.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/907948.shtml
英文地址,请注明出处:http://en.pswp.cn/news/907948.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C/C++】cmake实现Release版本禁用调试接口技巧

在 C 中通过 CMake 实现部分接口在 Release 版本不生效&#xff0c;可以通过条件编译结合 CMake 的构建类型判断来实现。以下是详细步骤&#xff1a; 1. 在 CMakeLists.txt 中定义配置相关宏 # 设置构建类型&#xff08;可选&#xff0c;但推荐显式设置&#xff09; if(NOT C…

Spring Boot中的WebSocket技术实现

WebSocket协议基础 WebSocket作为现代实时通信的核心技术,通过全双工TCP通道实现了接近实时的数据传输能力。该协议主要包含以下核心特性: 协议特点与通信机制 全双工通信:与HTTP等传统协议不同,WebSocket允许客户端和服务端同时发送和接收数据,消除了请求-响应模式的限…

无法发布到PowerBI?试试拆分它

无法发布到PowerBI&#xff1f;试试拆分它 在进行PowerBI发布时&#xff0c;可能会遇到如下两种无法发布到PowerBI的情况&#xff1a; 第一种&#xff0c;文件太大&#xff0c;无法发布&#xff0c;如图&#xff1a; 第二种&#xff1a;远程主机强迫关闭了一个现有的连接&…

光伏功率预测 | LSTM多变量单步光伏功率预测(Matlab完整源码和数据)

光伏功率预测 | MATLAB实现基于LSTM长短期记忆神经网络的光伏功率预测 目录 光伏功率预测 | MATLAB实现基于LSTM长短期记忆神经网络的光伏功率预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 光伏功率预测 | LSTM多变量单步光伏功率预测&#xff08;Matlab完整源码和…

【图像处理入门】2. Python中OpenCV与Matplotlib的图像操作指南

一、环境准备 import cv2 import numpy as np import matplotlib.pyplot as plt# 配置中文字体显示&#xff08;可选&#xff09; plt.rcParams[font.sans-serif] [SimHei] plt.rcParams[axes.unicode_minus] False二、图像的基本操作 1. 图像读取、显示与保存 使用OpenCV…

数据库系统概论(十一)SQL 集合查询 超详细讲解(附带例题表格对比带你一步步掌握)

数据库系统概论&#xff08;十一&#xff09;SQL 集合查询 超详细讲解&#xff08;附带例题表格对比带你一步步掌握&#xff09; 前言一、什么是集合查询&#xff1f;二、集合操作的三种类型1. 并操作2. 交操作3. 差操作 三、使用集合查询的前提条件四、常见问题与注意事项五、…

如何设计一个支持线上线下的通用订单模块 —— 面向本地生活服务行业的架构思路

一、背景与目标 在本地生活服务行业中&#xff0c;订单模块作为连接用户、商户、商品、支付、履约的核心组件&#xff0c;支撑着平台内多样化的业务形态&#xff0c;例如外卖配送、到店服务、团购核销、即时零售、预约预订、线下消费等。 设计一个可支持线上线下融合的通用订…

Django数据库连接报错 django.db.utils.NotSupportedError: MySQL 8 or later is required

可尝试换django版本 pip install django3.2.13 另外mysql下载地址 https://dev.mysql.com/downloads/installer/ 安装可以参考&#xff1a; https://blog.csdn.net/HHHQHHHQ/article/details/148125549 重点&#xff1a;用户变量添加 C:\Program Files\MySQL\MySQL Server …

github 提交失败,连接不上

1. 第一种情况&#xff0c;开了加速器&#xff0c;导致代理错误 删除hosts文件里相关的github代理地址 2. 有些ip不支持22端口连接,改为443连接 ssh -vT gitgithub.com // 命令执行结果 OpenSSH_for_Windows_9.5p1, LibreSSL 3.8.2 debug1: C…

24位高精度数据采集卡NET8860音频振动信号采集监测满足自动化测试应用现场的多样化需求

NET8860 高分辨率数据采集卡技术解析 阿尔泰科技的NET8860是一款高性能数据采集卡&#xff0c;具备8路同步模拟输入通道和24bit分辨率&#xff0c;适用于高精度信号采集场景。其输入量程覆盖10V、5V、2V、1V&#xff0c;采样速率高达256KS/s&#xff0c;能够满足多种工业与科研…

JavaScript 模块系统:CJS/AMD/UMD/ESM

文章目录 前言一、CommonJS (CJS) - Node.js 的同步模块系统1.1 设计背景1.2 浏览器兼容性问题1.3 Webpack 如何转换 CJS1.4 适用场景 二、AMD (Asynchronous Module Definition) - 浏览器异步加载方案2.1 设计背景2.2 为什么现代浏览器不原生支持 AMD2.3 Webpack/Rollup 如何处…

使用NMEA Tools生成GPS轨迹图

前言 在现代科技快速发展的时代&#xff0c;GPS定位技术已经广泛应用于各种领域&#xff0c;如导航、物流、运动追踪等。为了获取和分析GPS数据&#xff0c;我们常常需要使用一些专业的工具。本文将详细介绍如何使用一款名为“NMEA Tools”的APK应用&#xff0c;结合GPSVisual…

Word双栏英文论文排版攻略

word写双栏英文论文的注意事项 排版首先改字体添加连字符还没完呢有时候设置了两端对齐会出现这样的情况&#xff1a; 公式文献 等我下学期有时间了&#xff0c;一定要学习Latex啊&#xff0c;word写英文论文&#xff0c;不论是排版还是公式都很麻烦的&#xff0c;而Latex一键就…

FactoryBean 接口

Spring 框架中 FactoryBean 接口的特性&#xff0c;这是 Spring 提供的一种特殊机制&#xff0c;用于创建和管理复杂 Bean。让我通过示例和解释帮您理解这个概念。 一、FactoryBean 是什么&#xff1f; FactoryBean 是 Spring 框架提供的一个工厂接口&#xff0c;用于创建复杂…

MySQL + CloudCanal + Iceberg + StarRocks 构建全栈数据服务

简述 在业务数据快速膨胀的今天&#xff0c;企业对 低成本存储 与 实时查询分析能力 的需求愈发迫切。 本文将带你实战构建一条 MySQL 到 Iceberg 的数据链路&#xff0c;借助 CloudCanal 快速完成数据迁移与同步&#xff0c;并使用 StarRocks 完成数据查询等操作&#xff0c…

javaEE->多线程:线程池

线程池 线程诞生的意义&#xff1a;因为进程的创建/销毁&#xff0c;太重量了&#xff08;比较慢&#xff09; 但如果近一步提高创建/销毁的频率&#xff0c;线程的开销也不容忽视。 有两种方法可以提高效率&#xff1a; 1.协程&#xff08;轻量级线程&#xff09;&#xff…

【001】利用github搭建静态网站_essay

文章目录 1. 简介2. 先了解网址规则2.1 文件及网址形式2.2 相互访问 3. 搭建网页的过程3.1 网页文件3.2 github搭建仓库及文件上传3.3 搭建网站 1. 简介 相信大家都有过想要自己搭建一个稳定可靠的网站&#xff0c;github是一个不错的选择&#xff0c;本来国内有gitee可以搭建…

搜索引擎2.0(based elasticsearch6.8)设计与实现细节(完整版)

1 简介 1.1 背景 《搜索引擎onesearch 1.0-设计与实现.docx》介绍了1.0特性&#xff0c;搜索schema&#xff0c;agg&#xff0c;表达式搜索映射&#xff0c;本文介绍onesearch 2.0 新特性, 参考第2节 规划特性与发布计划 1.2 关键词 文档 Document elasticsearch 一行数据称为…

【ClickHouse】RollingBitmap

ClickHouse 的 RollingBitmap 是一种基于 Bitmap 的数据结构&#xff0c;用于高效处理数据的动态变化和时间窗口计算。以下是关于 ClickHouse RollingBitmap 的相关信息&#xff1a; RollingBitmap 的应用场景 RollingBitmap 主要用于需要处理动态数据和时间窗口计算的场景&am…

新版智慧社区(小区)智能化弱电系统解决方案

该方案聚焦新版智慧社区智能化弱电系统建设,以物联网、云计算、AI 人脸识别等技术为支撑,构建涵盖智能可视化对讲、智慧门禁、智能梯控、智慧停车、视频监控等核心系统的社区智能化体系,并通过智慧社区集成平台实现设备管理、数据统计、预警联动等功能。方案旨在解决传统社区…