React 常见面试题及答案

news/2025/3/3 5:20:24/

记录面试过程 常见问题,如有错误,欢迎批评指正

1. 什么是虚拟DOM?为什么它提高了性能?

虚拟DOM是React创建的一个轻量级JavaScript对象,表示真实DOM的结构。当状态变化时,React会生成新的虚拟DOM,并通过Diff算法比较新旧差异,仅更新变化的部分到真实DOM。这减少了直接操作DOM的次数,避免了昂贵的重绘和重排,从而提升性能。

2. React类组件和函数组件的区别?Hooks的作用是什么?

类组件:使用ES6类定义,有生命周期方法和状态(this.state)。

函数组件:无状态,但通过Hooks(如useState, useEffect)可管理状态和副作用。

Hooks作用:允许函数组件使用状态、生命周期等特性,简化代码并促进逻辑复用。

3. 解释useEffect的依赖数组的作用。

空数组[]:仅在组件挂载和卸载时执行(类似componentDidMount和componentWillUnmount)。

无数组:每次渲染后都执行。

包含变量的数组[a, b]:当a或b变化时执行。

4. 受控组件与非受控组件的区别?

受控组件:表单数据由React组件管理(通过value和onChange)。

非受控组件:表单数据由DOM自身管理,通过ref获取值(如<input ref={inputRef} />)。

5. 为什么列表渲染时需要key?

key帮助React识别元素变化,优化Diff算法效率。若缺少key,可能导致性能下降或渲染错误(如状态错乱)。

6. React Router如何实现动态路由和路由守卫?

动态路由:使用参数占位符(如<Route path="/user/:id" />),通过useParams()获取参数。

路由守卫:封装<Route>组件,结合useNavigate和条件渲染(如检查用户权限后重定向)。

7. React性能优化方法有哪些?

常用方法:

a、使用React.memo缓存组件。

b、useMemo和useCallback避免重复计算和函数重建。

c、代码分割(React.lazy + Suspense)实现懒加载。

d、避免在渲染函数中进行高开销操作。

8. Redux的核心概念是什么?与Context API的区别?

Redux核心:单一状态树,通过action触发reducer更新状态,使用中间件处理异步。

与Context区别Redux适合大型应用全局状态管理,提供调试工具和中间件;Context适合局部跨层级数据传递,无需额外库。

9. React合成事件是什么?

React将浏览器原生事件封装为合成事件,提供跨浏览器一致性,并自动管理事件绑定(事件委托到根节点)。

10. 错误边界(Error Boundaries)如何实现?

通过类组件的static getDerivedStateFromError()componentDidCatch()捕获子组件树中的错误,显示降级UI(函数组件暂不支持)。

11. React 18有哪些新特性?

主要特性:

a、并发模式(Concurrent Mode):可中断渲染,优化用户体验。

b、自动批处理:合并多个状态更新,减少渲染次数。

c、新Hooks:如useId生成唯一ID,useTransition管理非紧急更新。

12. Hooks使用规则有哪些?

规则:

只在函数组件或自定义Hooks顶层调用。

不能在循环、条件或嵌套函数中使用。

13. JSX是什么?如何转换为JavaScript?

JSX是语法糖,会被Babel转换为React.createElement()调用,生成React元素对象(如React.createElement('div', null, 'Hello'))。

14. 高阶组件(HOC)与Render Props的区别?

HOC:通过函数包装组件,返回增强功能的新组件(如withRouter(Component))。

Render Props:通过组件传递函数prop动态渲染内容(如<DataProvider render={data => <Child data={data} />} />)。

15. React严格模式的作用?

检测不安全的生命周期方法、过时的API使用,识别意外的副作用(如重复调用渲染函数),帮助提升代码质量。


http://www.ppmy.cn/news/1576210.html

相关文章

【Java项目】基于Spring Boot的网上商城购物系统

【Java项目】基于Spring Boot的网上商城购物系统 技术简介&#xff1a;采用Java技术、Spring Boot框架、MySQL数据库等实现。 系统简介&#xff1a;系统实现管理员&#xff1a;首页、个人中心、用户管理、商品分类管理、商品信息管理、订单评价管理、系统管理、订单管理&#x…

Java中的泛型类 --为集合的学习做准备

学习目标 ● 掌握在集合中正确使用泛型 ● 了解泛型类、泛型接口、泛型方法 ● 了解泛型上下限 ● 了解基本的使用场景 1.有关泛型 1.1泛型的概念 泛型&#xff08;Generics&#xff09;是Java中引入的参数化类型机制&#xff0c;允许在定义类、接口或方法时使用类型参数&a…

目标检测——数据处理

1. Mosaic 数据增强 Mosaic 数据增强步骤: (1). 选择四个图像&#xff1a; 从数据集中随机选择四张图像。这四张图像是用来组合成一个新图像的基础。 (2) 确定拼接位置&#xff1a; 设计一个新的画布(输入size的2倍)&#xff0c;在指定范围内找出一个随机点&#xff08;如…

快速列出MS Word中所有可用字体

Word中有很多字体&#xff0c;虽然在字体下拉列表中提供了字体的样例&#xff0c;但是并不全面&#xff0c;例如使用Batang字体的话&#xff0c;数字会显示成什么效果&#xff0c;就无法直观的看到。 打开Word应用程序&#xff0c;新建一个空白文档&#xff0c;按AltF11打开VBE…

C++中不同维度的数据保存与读取

C中不同维度的数据保存与读取 一、保存csv数据1.1 一维vector1.2 二维vector1.3 三维vector1.4 五维vector 二、读取csv数据2.1 一维vector2.2 二维vector2.3 三维vector2.4 五维vector 一、保存csv数据 1.1 一维vector void Save_bias(vector<double> &bias, stri…

【JavaWeb13】了解ES6的核心特性,对于提高JavaScript编程效率有哪些潜在影响?

文章目录 &#x1f30d;一. ES6 新特性❄️1. ES6 基本介绍❄️2. 基本使用2.1 let 声明变量2.2 const 声明常量/只读变量2.3 解构赋值2.4 模板字符串2.5 对象拓展运算符2.6 箭头函数 &#x1f30d;二. Promise❄️1. 基本使用❄️2. 如何解决回调地狱问题2.1回调地狱问题2.2 使…

TS二次封装axios学习总结

1.put请求 put请求一般用的很少&#xff0c;主要有两点区别。 1.PUT请求&#xff1a;如果两个请求相同&#xff0c;后一个请求会把第一个请求覆盖掉。&#xff08;所以PUT用来改资源&#xff09; Post请求&#xff1a;后一个请求不会把第一个请求覆盖掉。&#xff08;所以Pos…

【银河麒麟高级服务器操作系统】服务器测试业务耗时问题分析及处理全流程分享

更多银河麒麟操作系统产品及技术讨论&#xff0c;欢迎加入银河麒麟操作系统官方论坛 https://forum.kylinos.cn 了解更多银河麒麟操作系统全新产品&#xff0c;请点击访问 麒麟软件产品专区&#xff1a;https://product.kylinos.cn 开发者专区&#xff1a;https://developer…