【React】React原理面试题集锦

简介: 本文集合一些React的原理面试题,方便读者以后面试查漏补缺。作者给出自认为可以让面试官满意的简易答案,如果想要了解更深刻,可以点击链接查看对应的详细博文。在此对链接中的博文作者非常感谢🙏。

本文集合一些React的原理面试题,方便读者以后面试查漏补缺。作者给出自认为可以让面试官满意的简易答案,如果想要了解更深刻,可以点击链接查看对应的详细博文。在此对链接中的博文作者非常感谢🙏

  1. React 的设计思想是什么?

参考链接: https://github.com/camsong/react-basic (这个写的很好,React创始人的角度写的翻译版)

最核心的思想应该是通过函数(Function)完成数据(Data)->视图(UI)的转换,简称UI=f(Data).在这个过程中,会有很多问题。如下:

  • 一个函数是无法将Data转成UI的,所以会出现函数套函数的情况,这跟积木一样,积木与积木之前会有组合(组件化思想),积木与积木之间也要有桥梁进行支撑,这相当于函数与函数之间的数据流,于是催生出了Redux等数据流管理框架。
  • 函数的计算是非常耗时的,所以要尽量减少不必要的消耗。这在Dom层面上的体现便是虚拟Dom,在函数上的体现便是缓存计算结果。
  1. 虚拟Dom到底是什么?

参考链接: https://juejin.cn/post/6844903870229905422

虚拟Dom更像是HtmlJson化,它虽然不是Dom树,但含有Dom树的全部信息。之所以采取虚拟Dom,应该是Json的数据结构更方便做Diff处理。

至于其中的Diff算法,比对新老虚拟Dom的变化,然后将变化的部分更新到视图上。对应到代码上,就是一个 diff 函数,返回一个 patches(补丁)

  1. React的生命周期有哪些?

参考链接: https://juejin.cn/post/6914112105964634119

主要分为3个生命周期:

  • 挂载: constructorgetDerivedStateFromPropsrendercomponentDidMount
  • 更新:getDerivedStateFromPropsshouldComponentUpdaterendercomponentDidUpdate
  • 卸载: componentWillUnmount
  1. React的事件系统原理?

参考链接:https://juejin.cn/post/6955636911214067720(好文推荐)

首先React里的事件,例如onClick等,并不是原生事件,而是由原生事件合成的React事件。例如click事件合成onClick事件。blur,changeinput等合成onChange事件等。所以这里有3个问题。

  • 事件是如何合成的?构建React合成事件和原始事件的对应关系以及如何处理事件的关系。
  • 事件是如何绑定的?触发了React合成事件,React将这些合成事件分解为若干个原始事件,然后冒泡执行(有些事件会在捕获阶段执行)。
  • 事件是如何触发的?会进入统一监听器dispatchEvent进行批量更新,然后插件合成事件源对象,得到事件执行队列,该队列用于模拟事件的捕获->事件源-> 事件冒泡的过程,最后执行事件队列,如果有阻止冒泡那么退出循环。
  1. JSX是什么,它和JS有什么区别?

参考链接:https://juejin.cn/post/7182382408807743548

JSX是react的语法糖,它允许在html中写JS,它不能被浏览器直接识别,需要通过webpack、babel之类的编译工具转换为JS执行

区别

JSX

JS

如何编译

通过babel编译转换

可直接编译

引入方式

使JS的拓展,可在html中直接写

需要通过scripts标签引入

  1. React的Fiber架构?

参考链接:https://juejin.cn/post/6993973502852202503

首先什么是Fiber: 在React16后提出的概念。FiberReact的一个执行单元,Fiber的主要思想是将UI渲染分成更小的任务,每一个小任务指的就是 Fiber的节点, 拆分的小任务会在浏览器的空闲时间被执行。每个任务单元执行完成后,React 都会检查是否还有空余时间,如果有就交换主线程的控制权,从而能让React平滑渲染UI,避免卡顿。

Fiber架构解决的问题:解决React在处理复杂UI时性能不佳的问题。

目录
相关文章
|
6天前
|
消息中间件 存储 缓存
大厂面试高频:Kafka 工作原理 ( 详细图解 )
本文详细解析了 Kafka 的核心架构和实现原理,消息中间件是亿级互联网架构的基石,大厂面试高频,非常重要,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:Kafka 工作原理 ( 详细图解 )
|
3月前
|
安全 Java 容器
【Java集合类面试二十七】、谈谈CopyOnWriteArrayList的原理
CopyOnWriteArrayList是一种线程安全的ArrayList,通过在写操作时复制新数组来保证线程安全,适用于读多写少的场景,但可能因内存占用和无法保证实时性而有性能问题。
|
8天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
8天前
|
存储 安全 Java
面试高频:Synchronized 原理,建议收藏备用 !
本文详解Synchronized原理,包括其作用、使用方式、底层实现及锁升级机制。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
面试高频:Synchronized 原理,建议收藏备用 !
|
1月前
|
存储 监控 算法
美团面试:说说 G1垃圾回收 底层原理?说说你 JVM 调优的过程 ?
尼恩提示: G1垃圾回收 原理非常重要, 是面试的重点, 大家一定要好好掌握
美团面试:说说 G1垃圾回收 底层原理?说说你 JVM 调优的过程  ?
|
1月前
|
SQL 存储 关系型数据库
美团面试:binlog、redo log、undo log的底层原理是什么?它们分别实现ACID的哪个特性?
老架构师尼恩在其读者交流群中分享了关于 MySQL 中 redo log、undo log 和 binlog 的面试题及其答案。这些问题涵盖了事务的 ACID 特性、日志的一致性问题、SQL 语句的执行流程等。尼恩详细解释了这些日志的作用、所在架构层级、日志形式、缓存机制以及写文件方式等内容。他还提供了多个面试题的详细解答,帮助读者系统化地掌握这些知识点,提升面试表现。此外,尼恩还推荐了《尼恩Java面试宝典PDF》和其他技术圣经系列PDF,帮助读者进一步巩固知识,实现“offer自由”。
美团面试:binlog、redo log、undo log的底层原理是什么?它们分别实现ACID的哪个特性?
|
30天前
|
负载均衡 算法 Java
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
40岁老架构师尼恩分享了关于SpringCloud核心组件的底层原理,特别是针对蚂蚁集团面试中常见的面试题进行了详细解析。内容涵盖了Nacos注册中心的AP/CP模式、Distro和Raft分布式协议、Sentinel的高可用组件、负载均衡组件的实现原理等。尼恩强调了系统化学习的重要性,推荐了《尼恩Java面试宝典PDF》等资料,帮助读者更好地准备面试,提高技术实力,最终实现“offer自由”。更多技术资料和指导,可关注公众号【技术自由圈】获取。
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
|
30天前
|
SQL 关系型数据库 MySQL
阿里面试:MYSQL 事务ACID,底层原理是什么? 具体是如何实现的?
尼恩,一位40岁的资深架构师,通过其丰富的经验和深厚的技術功底,为众多读者提供了宝贵的面试指导和技术分享。在他的读者交流群中,许多小伙伴获得了来自一线互联网企业的面试机会,并成功应对了诸如事务ACID特性实现、MVCC等相关面试题。尼恩特别整理了这些常见面试题的系统化解答,形成了《MVCC 学习圣经:一次穿透MYSQL MVCC》PDF文档,旨在帮助大家在面试中展示出扎实的技术功底,提高面试成功率。此外,他还编写了《尼恩Java面试宝典》等资料,涵盖了大量面试题和答案,帮助读者全面提升技术面试的表现。这些资料不仅内容详实,而且持续更新,是求职者备战技术面试的宝贵资源。
阿里面试:MYSQL 事务ACID,底层原理是什么? 具体是如何实现的?
|
30天前
|
消息中间件 Java Linux
得物面试:什么是零复制?说说 零复制 底层原理?(吊打面试官)
尼恩,40岁老架构师,专注于技术分享与面试辅导。近期,尼恩的读者群中有小伙伴在面试一线互联网企业如得物、阿里、滴滴等时,遇到了关于零复制技术的重要问题。为此,尼恩系统化地整理了零复制的底层原理,包括RocketMQ和Kafka的零复制实现,以及DMA、mmap、sendfile等技术的应用。尼恩还计划推出一系列文章,深入探讨Netty、Kafka、RocketMQ等框架的零复制技术,帮助大家在面试中脱颖而出,顺利拿到高薪Offer。此外,尼恩还提供了《尼恩Java面试宝典》PDF等资源,助力大家提升技术水平。更多内容请关注尼恩的公众号【技术自由圈】。
得物面试:什么是零复制?说说 零复制 底层原理?(吊打面试官)
|
1月前
|
存储 前端开发 测试技术
React Hooks 的工作原理
【10月更文挑战第1天】