本文集合一些React的原理面试题,方便读者以后面试查漏补缺。作者给出自认为可以让面试官满意的简易答案,如果想要了解更深刻,可以点击链接查看对应的详细博文。在此对链接中的博文作者非常感谢。
参考链接: https://github.com/camsong/react-basic (这个写的很好,React创始人的角度写的翻译版)
最核心的思想应该是通过函数(Function)完成数据(Data)->视图(UI)的转换,简称UI=f(Data).在这个过程中,会有很多问题。如下:
参考链接: https://juejin.cn/post/6844903870229905422
虚拟Dom
更像是Html
的Json
化,它虽然不是Dom
树,但含有Dom
树的全部信息。之所以采取虚拟Dom
,应该是Json
的数据结构更方便做Diff处理。
至于其中的Diff
算法,比对新老虚拟Dom
的变化,然后将变化的部分更新到视图上。对应到代码上,就是一个 diff
函数,返回一个 patches
(补丁)
参考链接: https://juejin.cn/post/6914112105964634119
主要分为3个生命周期:
constructor
,getDerivedStateFromProps
,render
,componentDidMount
getDerivedStateFromProps
,shouldComponentUpdate
,render
,componentDidUpdate
componentWillUnmount
参考链接:https://juejin.cn/post/6955636911214067720(好文推荐)
首先React里的事件,例如onClick
等,并不是原生事件,而是由原生事件合成的React事件。例如click
事件合成onClick
事件。blur
,change
,input
等合成onChange
事件等。所以这里有3个问题。
dispatchEvent
进行批量更新,然后插件合成事件源对象,得到事件执行队列,该队列用于模拟事件的捕获
->事件源
-> 事件冒泡
的过程,最后执行事件队列,如果有阻止冒泡那么退出循环。参考链接:https://juejin.cn/post/7182382408807743548
JSX是react的语法糖,它允许在html中写JS,它不能被浏览器直接识别,需要通过webpack、babel之类的编译工具转换为JS执行
区别 | JSX | JS |
---|---|---|
如何编译 | 通过babel编译转换 | 可直接编译 |
引入方式 | 使JS的拓展,可在html中直接写 | 需要通过scripts标签引入 |
参考链接:https://juejin.cn/post/6993973502852202503
首先什么是Fiber
: 在React16后提出的概念。Fiber
是 React
的一个执行单元,Fiber的主要思想是将UI渲染分成更小的任务,每一个小任务指的就是 Fiber的节点, 拆分的小任务会在浏览器的空闲时间被执行。每个任务单元执行完成后,React
都会检查是否还有空余时间,如果有就交换主线程的控制权,从而能让React平滑渲染UI,避免卡顿。
Fiber
架构解决的问题:解决React
在处理复杂UI时性能不佳的问题。