🍉前言
本篇文章主要写的是前端高频面试题(React框架)篇
面试题参考文章:
🌍正文
1.你了解 React 吗?
React 是 facebook 搞出来的一个轻量级的组件库,用于解决前端视图层的一些问 题,就是 MVC 中 V 层的问题,它内部的 Instagram 网站就是用 React 搭建的。
2. React 解决了什么问题?
- 组件复用问题
- 性能问题
- 兼容性问题
3. React 的协议?
React 遵循的协议是“BSD 许可证 + 专利开源协议”,这个协议比较奇葩,如果你的产品跟 facebook 没有竞争关系,你可以自由的使用 React,但是如果有竞争关系,你的 React 的使用许可将会被取消。
4.了解 shouldComponentUpdate 吗?
React 虚拟 dom 技术要求不断的将 dom 和虚拟 dom 进行 diff 比较,如果 dom 树比价大, 这种比较操作会比较耗时,因此 React 提供了 shouldComponentUpdate 这种补丁函数,如 果对于一些变化,如果我们不希望某个组件刷新,或者刷新后跟原来其实一样,就可以 使用这个函数直接告诉 React,省去 diff 操作,进一步的提高了效率。
5. React 的工作原理?
React 会创建一个虚拟 DOM(virtual DOM)。当一个组件中的状态改变时,React 首先会 通过 “diffing ” 算法来标记虚拟 DOM 中的改变,第二步是调节(reconciliation ),会用 diff 的结果来更新 DOM。
6. 使用 React 有何优点?
- 只需要查看
render 函数机会很容易知道一个组件是如何被渲染出来的 - JSX 的引入,使得组件的代码更加可读,也更容易看懂组件的布局,或者组件之间是如何互相引用的
- 支持服务端渲染,这可以改进 SEO 和性能
- 易于测试
- React 只关注 View 层,所以可以和其他任何框架(如
Backbone.js ,``Angular.js`) 一起使用
7.删除数组用 delete 和 Vue.delete 有什么
delete :只是被删除数组成员变为 empty / undefined ,其他元素键值不变Vue.delete :直接删了数组成员,并改变了数组的键值(对象是响应式的,确保 删除能触发更新视图,这个方法主要用于避开 Vue 不能检测到属性被删除的限制)
8. 展示组件(Presentational component)和容器组件(Container component)之间有何不同?
- 展示组件关心组件看起来是什么。展示专门通过 props 接受数据和回调,并且几乎不 会有自身的状态,但当展示组件拥有自身的状态时,通常也只关心 UI 状态而不是数据的状态
- 容器组件则更关心组件是如何运作的。容器组件会为展示组件或者其它容器组件提供 数据和行为(behavior),它们会调用 Flux actions,并将其作为回调提供给展示组件。容器组件经常是有状态的,因为它们是(其它组件的)数据源
9. 类组件(Class component )和函数式组件(Functional component )之间有何不同?
- 类组件不仅允许你使用更多额外的功能,如组件自身的状态和生命周期钩子,也能使 组件直接访问 store 并维持状态
- 当组件仅是接收 props,并将组件自身渲染到页面时,该组件就是一个 ‘无状态组件 (stateless component)’,可以使用一个纯函数来创建这样的组件。这种组件也被称为哑组件(
dumb components )或展示组件
10. (组件的)状态(state)和属性(props)之间有何不同?
- State 是一种数据结构,用于组件挂载时所需数据的默认值。State 可能会随着时间的 推移而发生突变,但多数时候是作为用户事件行为的结果。
- Props(properties 的简写)则是组件的配置。props 由父组件传递给子组件,并且就子组 件而言,props 是不可变的(immutable)。组件不能改变自身的 props,但是可以把其子组 件的 props 放在一起(统一管理)。Props 也不仅仅是数据–回调函数也可以通过 props 传递。
11.应该在 React 组件的何处发起 Ajax请求?
在 React 组件中,应该在 componentDidMount 中发起网络请求。这个方法会在组件第 一次“挂载”(被添加到 DOM)时执行,在组件的生命周期中仅会执行一次。更重要的是, 你不能保证在组件挂载之前 Ajax 请求已经完成,如果是这样,也就意味着你将尝试在 一个未挂载的组件上调用 setState ,这将不起作用。在 componentDidMount 中发起网络 请求将保证这有一个组件可以更新了。
12.在 React 中,refs 的作用是什么?
Refs 可以用于获取一个 DOM 节点或者 React 组件的引用。何时使用 refs 的好的示例 有管理焦点/文本选择,触发命令动画,或者和第三方 DOM 库集成。你应该避免使用 String 类型的 Refs 和内联的 ref 回调。Refs 回调是 React 所推荐的
13.何为高阶组件(higher order component )?
高阶组件是一个以组件为参数并返回一个新组件的函数。HOC 运行你重用代码、逻辑 和引导抽象。最常见的可能是 Redux 的 connect 函数。除了简单分享工具库和简单的 组合,HOC 最好的方式是共享 React 组件之间的行为。如果你发现你在不同的地方写 了大量代码来做同一件事时,就应该考虑将代码重构为可重用的 HOC
14. 使用箭头函数(arrow functions )的优点是什么?
- 清晰:当一切都是一个箭头函数,任何常规函数都可以立即用于定义作用域。开发者 总是可以查找 next-higher 函数语句,以查看 this 的值。
- 简单:箭头函数易于阅读和书写。
- 作用域安全:在箭头函数之前,每一个新创建的函数都有定义自身的 this 值(在构造 函数中是新对象;在严格模式下,函数调用中的 this 是未定义的;如果函数被称为“对 象方法”,则为基础对象等),但箭头函数不会,它会使用封闭执行上下文的 this 值。
15. 为什么建议传递给 setState 的参数是一个 callback 而不是
因为this.props 和 this.state 的更新可能是异步的,不能依赖它们的值去计算下一个 state。
16. 除了在构造函数中绑定 this,还有其它方法吗?
可以使用属性初始值设定项(property initializers )来正确绑定回调,create-React-app 也是 默认支持的。在回调中你可以使用箭头函数,但问题是每次组件渲染时都会创建一个新的回调。
17. 怎么阻止组件的渲染?
在组件的 render 方法中返回 null 并不会影响触发组件的生命周期方法
18. 当渲染一个列表时,何为 key?设置 key 的目的是什么?
Keys 会有助于 React 识别哪些 items 改变了,被添加了或者被移除了。Keys 应该被赋 予数组内的元素以赋予(DOM)元素一个稳定的标识,选择一个 key 的最佳方法是使用一 个字符串,该字符串能惟一地标识一个列表项。很多时候你会使用数据中的 IDs 作为 keys,当你没有稳定的 IDs 用于被渲染的 items 时,可以使用项目索引作为渲染项的 key,但这种方式并不推荐,如果 items 可以重新排序,就会导致 re-render 变慢
19. angularJs 和 React 区别
React 对比 Angular 是思想上的转变,它也并不是一个库,是一种开发理念,组件化,分 治的管理,数据与 view 的一体化。它只有一个中心,发出状态,渲染 view,对于虚拟 dom 它并没有提高渲染页面的性能,它提供更多的是利用 jsx 便捷生成 dom 元素,利用组件 概念进行分治管理页面每个部分(例如 header section footer slider)
20.redux 中间件
中间件提供第三方插件的模式,自定义拦截 action -> reducer 的过程。变为action -> middlewares -> reducer 。这种机制可以让我们改变数据流,实现如异步 action ,action 过 滤,日志输出,异常报告等功能。 常见的中间件:redux-logger :提供日志输出;redux-thunk :处理异步操作;redux-promise : 处理异步操作;actionCreator 的返回值是 promise
21. redux 有什么缺点
1.一个组件所需要的数据,必须由父组件传过来,而不能像 flux 中直接从 store 取。
2.当一个组件相关数据更新时,即使父组件不需要用到这个组件,父组件还是会重新 render,可能会有效率影响,或者需要写复杂的 shouldComponentUpdate 进行判断。
22. React 组件的划分业务组件技术组件?
根据组件的职责通常把组件分为 UI 组件和容器组件。UI 组件负责 UI 的呈现,容器组 件负责管理数据和逻辑。两者通过 React-Redux 提供 connect 方法联系起来。
23. React 生命周期
一、初始化阶段
getDefaultProps :获取实例的默认属性getInitialState :获取每个实例的初始化状态componentWillMount :组件即将被装载、渲染到页面上render :组件在这里生成虚拟的 DOMcomponentDidMount :组件真正在被装载之后
二、运行中状态
componentWillReceiveProps :组件将要接收到属性的时候调用shouldComponentUpdate :组件接受到新属性或者新状态的时候(可以返回 false,接收数据 后不更新,阻止 render 调用,后面的函数不会被继续执行了)componentWillUpdate :组件即将更新不能修改属性和状态render :组件重新描绘componentDidUpdate :组件已经更新
三、销毁阶段
componentWillUnmount :组件即将销毁
24. React 性能优化是哪个周期函数?
shouldComponentUpdate 这个方法用来判断是否需要调用 render 方法重新描绘 dom。因 为 dom 的描绘非常消耗性能,如果我们能在 shouldComponentUpdate 方法中能够写出更 优化的 dom diff 算法,可以极大的提高性能。
25. React 性能优化方案
- 重写
shouldComponentUpdate 来避免不必要的dom操作 - 使用
production 版本的 React.js - 使用
key 来帮助React 识别列表中所有子组件的最小变化
26.简述 flux 思想
Flux 的最大特点,就是数据的"单向流动"。
- 用户访问 View
- View 发出用户的 action
- Dispatcher 收到 Action,要求 Store 进行相应的更新
- Store 更新后,发出一个 “change” 事件
- View 手到 “change”事件后,更新页面
27. 说说React项目使用的Mern 脚手架
MERN 是脚手架的工具,它可以很容易地使用 Mongo , Express , React and NodeJS 生成同构 JS 应用。它最大限度地减少安装时间,并得到您使用的成熟技术来加速开发。
🎃专栏分享:
React框架相关面试题就更新到这里啦,相关 Web前端面试题 可以订阅专栏哦 🥰 专栏地址:《面试题》
?
名
言
警
句
:
说
能
做
的
做
说
过
的
\textcolor{red} {名言警句:说能做的做说过的}
名言警句:说能做的做说过的
?
原
创
不
易
,
还
希
望
各
位
大
佬
支
持
一
下
\textcolor{blue}{原创不易,还希望各位大佬支持一下}
原创不易,还希望各位大佬支持一下
👍
点
赞
,
你
的
认
可
是
我
创
作
的
动
力
!
\textcolor{green}{点赞,你的认可是我创作的动力!}
点赞,你的认可是我创作的动力!
??
收
藏
,
你
的
青
睐
是
我
努
力
的
方
向
!
\textcolor{green}{收藏,你的青睐是我努力的方向!}
收藏,你的青睐是我努力的方向!
??
评
论
,
你
的
意
见
是
我
进
步
的
财
富
!
\textcolor{green}{评论,你的意见是我进步的财富!}
评论,你的意见是我进步的财富!
|