Maison > Article > interface Web > 35 questions d'entretien que vous devez connaître et maîtriser React
[Recommandations de sujets connexes : questions d'entretien de réaction (2020)]
Thème : React
Difficulté : ⭐
Le DOM virtuel (VDOM) est une représentation en mémoire du vrai DOM. La représentation de l'interface utilisateur est conservée en mémoire et synchronisée avec le DOM réel. Il s'agit d'une étape qui se produit entre la fonction de rendu appelée et l'élément affiché à l'écran. L'ensemble du processus est appelé réconciliation.
Thème : React
Difficulté : ⭐⭐
state
et les hooks de cycle de vie. props
et le restitue sur la page, il s'agit d'un composant sans état et d'un composant fonctionnel. Il est également appelé composant stupide ou composant d'affichage. Bien sûr, il existe une différence entre les composants de fonction et les composants de classe, et les performances des composants de fonction sont supérieures à celles des composants de classe, car les composants de classe doivent être instanciés lorsqu'ils sont utilisés, tandis que les composants de fonction directement exécuter la récupération de la fonction Renvoyez simplement le résultat. Pour améliorer les performances, essayez d'utiliser des composants fonctionnels.
Différence | Composant de fonction | Composant de classe | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Y a-t-il ce
|
Non | Oui | ||||||||||||
Existe-t-il un cycle de vie | Non | Oui | ||||||||||||
Y a-t-il un état
|
Non | td>Oui |
Thème : React
Difficulté : ⭐⭐
Refs
Fournit un moyen d'accéder aux nœuds DOM ou aux éléments React créés dans la méthode render
. Dans un flux de données typique, props
est le seul moyen pour les composants parent-enfant d'interagir. Si vous souhaitez modifier un composant enfant, vous devez le restituer avec un nouveau pros
. Il y a des exceptions à tout. Dans certains cas, nous devons forcer la modification des descendants en dehors du flux de données typique. Dans ce cas, Refs
peut être utilisé.
Nous pouvons ajouter un attribut ref
au composant à utiliser. La valeur de cet attribut est une fonction de rappel qui reçoit l'élément DOM sous-jacent ou l'instance montée du composant comme premier paramètre.
class UnControlledForm extends Component { handleSubmit = () => { console.log("Input Value: ", this.input.value) } render () { return ( <form onSubmit={this.handleSubmit}> <input type='text' ref={(input) => this.input = input} /> <button type='submit'>Submit</button> </form> ) } }
Veuillez noter que l'élément input
possède un attribut ref
dont la valeur est une fonction. Cette fonction reçoit l'élément DOM réel en entrée, puis le place sur l'instance afin qu'il soit accessible dans la fonction handleSubmit
.
On comprend souvent à tort que refs
ne peut être utilisé qu'au sein des composants de classe, mais refs
peut également être utilisé avec des composants de fonction en tirant parti des fermetures dans JS.
function CustomForm ({handleSubmit}) { let inputElement return ( <form onSubmit={() => handleSubmit(inputElement.value)}> <input type='text' ref={(input) => inputElement = input} /> <button type='submit'>Submit</button> </form> ) }
Sujet : React
Difficulté : ⭐⭐
Afin de résoudre des problèmes croisés Problèmes de navigateur Problème de compatibilité, SyntheticEvent
l'instance sera transmise à votre fonction de gestionnaire d'événements, SyntheticEvent
est le wrapper d'événement natif du navigateur multi-navigateur de React, il a également la même interface que les événements natifs du navigateur, y compris stopPropagation()
et preventDefault()
.
Fait intéressant, React n'attache pas réellement d'événements aux nœuds enfants eux-mêmes. React utilise un seul écouteur d'événements pour écouter tous les événements au niveau supérieur. C'est bon pour les performances et signifie que React n'a pas besoin de suivre les écouteurs d'événements lors de la mise à jour du DOM.
Thème : React
Difficulté : ⭐⭐
props
et state
sont des objets JS normaux. Bien qu'ils contiennent tous deux des informations affectant la sortie rendue, leur fonctionnalité en termes de composants est différente. Autrement dit,
state
est un composant qui gère ses propres données et contrôle son propre état, qui est variable. props
est un paramètre de données externe transmis ; in et est immuable ; state
sont appelés composants sans état, et ceux avec state
sont appelés composants avec état props
et moins avec , c'est-à-dire écrire davantage de composants sans état. state
Difficulté : ⭐⭐Les références sont créées en utilisant
, et attaché à l'élément React via l'attribut React.createRef()
. Lors de la construction d'un composant, il est courant d'attribuer ref
aux propriétés d'instance afin qu'elles puissent être référencées dans tout le composant. Refs
class MyComponent extends React.Component { constructor(props) { super(props); this.myRef = React.createRef(); } render() { return <p ref={this.myRef} />; } }Ou utilisez-le comme ceci :
class UserForm extends Component { handleSubmit = () => { console.log("Input Value is: ", this.input.value) } render () { return ( <form onSubmit={this.handleSubmit}> <input type='text' ref={(input) => this.input = input} /> // Access DOM input in handle submit <button type='submit'>Submit</button> </form> ) } }
Difficulté : ⭐⭐
Composant d'ordre supérieur (HOC) est une fonction qui accepte un composant et renvoie un nouveau composant. Fondamentalement, il s'agit d'un modèle dérivé de la fonctionnalité de composition de React, appelé Pure Components car ils peuvent accepter n'importe quel sous-composant fourni dynamiquement, mais ne modifient ni ne copient le comportement du composant d'entrée.
const EnhancedComponent = higherOrderComponent(WrappedComponent);HOC peut être utilisé pour de nombreux cas d'utilisation ci-dessous
super
en paramètre ? props
Difficulté : ⭐⭐Les constructeurs de sous-classes ne peuvent pas utiliser les références
jusqu'à ce que la méthode super()
soit appelée, et il en va de même pour les sous-classes ES6. La principale raison de passer le paramètre this
à l'appel props
est de pouvoir obtenir le passé dans super()
via this.props
dans le sous-constructeur. props
Passer des accessoires
class MyComponent extends React.Component { constructor(props) { super(props); console.log(this.props); // { name: 'sudheer',age: 30 } } }
Ne pas passer des accessoires
class MyComponent extends React.Component { constructor(props) { super(); console.log(this.props); // undefined // 但是 Props 参数仍然可用 console.log(props); // Prints { name: 'sudheer',age: 30 } } render() { // 构造函数外部不受影响 console.log(this.props) // { name: 'sudheer',age: 30 } } }L'exemple ci-dessus révèle quelque chose. Le comportement de
n'est différent qu'à l'intérieur du constructeur, il est le même en dehors du constructeur. props
Difficulté : ⭐⭐⭐En HTML, les éléments de formulaire comme
, <input>
et <textarea></textarea>
conservent généralement leur propre état, et mises à jour basées sur les entrées de l'utilisateur. Lorsque l'utilisateur soumet le formulaire, les valeurs des éléments ci-dessus seront envoyées avec le formulaire. <select></select>
而 React 的工作方式则不同。包含表单的组件将跟踪其状态中的输入值,并在每次回调函数(例如onChange
)触发时重新渲染组件,因为状态被更新。以这种方式由 React 控制其值的输入表单元素称为受控组件。
主题: React
难度: ⭐⭐⭐
问题:
const element = ( <h1 className="greeting"> Hello, world! </h1> )
上述代码如何使用 React.createElement
来实现:
const element = React.createElement( 'h1', {className: 'greeting'}, 'Hello, world!' );
主题: React
难度: ⭐⭐⭐
当 Facebook 第一次发布 React 时,他们还引入了一种新的 JS 方言 JSX
,将原始 HTML 模板嵌入到 JS 代码中。JSX 代码本身不能被浏览器读取,必须使用Babel
和webpack
等工具将其转换为传统的JS。很多开发人员就能无意识使用 JSX,因为它已经与 React 结合在一直了。
class MyComponent extends React.Component { render() { let props = this.props; return ( <p className="my-component"> <a href={props.url}>{props.name}</a> </p> ); } }
主题: React
难度: ⭐⭐⭐
请看下面的代码:
答案:
1.在构造函数没有将 props
传递给 super
,它应该包括以下行
constructor(props) { super(props); // ... }
2.事件监听器(通过addEventListener()
分配时)的作用域不正确,因为 ES6 不提供自动绑定。因此,开发人员可以在构造函数中重新分配clickHandler
来包含正确的绑定:
constructor(props) { super(props); this.clickHandler = this.clickHandler.bind(this); // ... }
state
呢 ?主题: React
难度: ⭐⭐⭐
如果试图直接更新 state
,则不会重新渲染组件。
// 错误 This.state.message = 'Hello world';
需要使用setState()
方法来更新 state
。它调度对组件state
对象的更新。当state
改变时,组件通过重新渲染来响应:
// 正确做法 This.setState({message: ‘Hello World’});
主题: React
难度: ⭐⭐⭐
在组件生命周期中有四个不同的阶段:
componentWillMount
和componentDidMount
生命周期方法。shouldComponentUpdate
、componentWillUpdate
和componentDidUpdate
生命周期方法。componentWillUnmount
生命周期方法。除以上四个常用生命周期外,还有一个错误处理的阶段:
Error Handling:在这个阶段,不论在渲染的过程中,还是在生命周期方法中或是在任何子组件的构造函数中发生错误,该组件都会被调用。这个阶段包含了 componentDidCatch
生命周期方法。
主题: React
难度: ⭐⭐⭐
componentWillMount
:在渲染之前执行,用于根组件中的 App 级配置。componentDidMount
:在第一次渲染之后执行,可以在这里做AJAX请求,DOM 的操作或状态更新以及设置事件监听器。componentWillReceiveProps
:在初始化render
的时候不会执行,它会在组件接受到新的状态(Props)时被触发,一般用于父组件状态更新时子组件的重新渲染shouldComponentUpdate
:确定是否更新组件。默认情况下,它返回true
。如果确定在 state
或 props
更新后组件不需要在重新渲染,则可以返回false
,这是一个提高性能的方法。componentWillUpdate
:在shouldComponentUpdate
返回 true
确定要更新组件之前件之前执行。componentDidUpdate
:它主要用于更新DOM以响应props
或state
更改。componentWillUnmount
:它用于取消任何的网络请求,或删除与组件关联的所有事件监听器。主题: React
难度: ⭐⭐⭐
...
在React(使用JSX)代码中做什么?它叫什么?
<Modal {...this.props} title='Modal heading' animation={false}/>
这个叫扩展操作符号或者展开操作符,例如,如果this.props
包含a:1
和b:2
,则
<Modal {...this.props} title='Modal heading' animation={false}>
等价于下面内容:
<Modal a={this.props.a} b={this.props.b} title='Modal heading' animation={false}>
扩展符号不仅适用于该用例,而且对于创建具有现有对象的大多数(或全部)属性的新对象非常方便,在更新state
咱们就经常这么做:
this.setState(prevState => { return {foo: {...prevState.foo, a: "updated"}}; });
主题: React
难度: ⭐⭐⭐
首先,Hooks 通常支持提取和重用跨多个组件通用的有状态逻辑,而无需承担高阶组件或渲染 props
的负担。Hooks
可以轻松地操作函数组件的状态,而不需要将它们转换为类组件。
Hooks 在类中不起作用,通过使用它们,咱们可以完全避免使用生命周期方法,例如 componentDidMount
、componentDidUpdate
、componentWillUnmount
。相反,使用像useEffect
这样的内置钩子。
主题: React
难度: ⭐⭐⭐
Hooks是 React 16.8 中的新添加内容。它们允许在不编写类的情况下使用state
和其他 React 特性。使用 Hooks,可以从组件中提取有状态逻辑,这样就可以独立地测试和重用它。Hooks 允许咱们在不改变组件层次结构的情况下重用有状态逻辑,这样在许多组件之间或与社区共享 Hooks 变得很容易。
useState()
是什么?主题: React
难度: ⭐⭐⭐
下面说明useState(0)
的用途:
... const [count, setCounter] = useState(0); const [moreStuff, setMoreStuff] = useState(...); ... const setCount = () => { setCounter(count + 1); setMoreStuff(...); ... };
useState
是一个内置的 React Hook。useState(0)
返回一个元组,其中第一个参数count
是计数器的当前状态,setCounter
提供更新计数器状态的方法。
咱们可以在任何地方使用setCounter
方法更新计数状态-在这种情况下,咱们在setCount
函数内部使用它可以做更多的事情,使用 Hooks,能够使咱们的代码保持更多功能,还可以避免过多使用基于类的组件。
主题: React
难度: ⭐⭐⭐
React 的StrictMode
是一种辅助组件,可以帮助咱们编写更好的 react 组件,可以使用<strictmode></strictmode>
包装一组组件,并且可以帮咱们以下检查:
主题: React
难度: ⭐⭐⭐
在 JS 中,this
值会根据当前上下文变化。在 React 类组件方法中,开发人员通常希望 this
引用组件的当前实例,因此有必要将这些方法绑定到实例。通常这是在构造函数中完成的:
class SubmitButton extends React.Component { constructor(props) { super(props); this.state = { isFormSubmitted: false }; this.handleSubmit = this.handleSubmit.bind(this); } handleSubmit() { this.setState({ isFormSubmitted: true }); } render() { return ( <button onClick={this.handleSubmit}>Submit</button> ) } }
主题: React
难度: ⭐⭐⭐
在构建 React 应用程序时,在多层嵌套组件来使用另一个嵌套组件提供的数据。最简单的方法是将一个 prop
从每个组件一层层的传递下去,从源组件传递到深层嵌套组件,这叫做prop drilling。
prop drilling
的主要缺点是原本不需要数据的组件变得不必要地复杂,并且难以维护。
为了避免prop drilling
,一种常用的方法是使用React Context。通过定义提供数据的Provider
组件,并允许嵌套的组件通过Consumer
组件或useContext
Hook 使用上下文数据。
主题: React
难度: ⭐⭐⭐
传统的 MVC 模式在分离数据(Model)、UI(View和逻辑(Controller)方面工作得很好,但是 MVC 架构经常遇到两个主要问题:
数据流不够清晰:跨视图发生的级联更新常常会导致混乱的事件网络,难于调试。
缺乏数据完整性:模型数据可以在任何地方发生突变,从而在整个UI中产生不可预测的结果。
使用 Flux 模式的复杂用户界面不再遭受级联更新,任何给定的React 组件都能够根据 store
提供的数据重建其状态。Flux 模式还通过限制对共享数据的直接访问来加强数据完整性。
主题: React
难度: ⭐⭐⭐
尽管非受控组件通常更易于实现,因为只需使用refs
即可从 DOM 中获取值,但通常建议优先选择受控制的组件,而不是非受控制的组件。
这样做的主要原因是受控组件支持即时字段验证,允许有条件地禁用/启用按钮,强制输入格式。
主题: React
难度: ⭐⭐⭐⭐
这段代码有什么问题:
this.setState((prevState, props) => { return { streak: prevState.streak + props.count } })
答案:
没有什么问题。这种方式很少被使用,咱们可以将一个函数传递给setState
,该函数接收上一个 state
的值和当前的props
,并返回一个新的状态,如果咱们需要根据以前的状态重新设置状态,推荐使用这种方式。
主题: React
难度: ⭐⭐⭐⭐
Context
通过组件树提供了一个传递数据的方法,从而避免了在每一个层级手动的传递 props
属性。
主题: React
难度: ⭐⭐⭐⭐
Fiber 是 React 16 中新的协调引擎或重新实现核心算法。它的主要目标是支持虚拟DOM的增量渲染。React Fiber 的目标是提高其在动画、布局、手势、暂停、中止或重用等方面的适用性,并为不同类型的更新分配优先级,以及新的并发原语。
React Fiber 的目标是增强其在动画、布局和手势等领域的适用性。它的主要特性是增量渲染:能够将渲染工作分割成块,并将其分散到多个帧中。
主题: React
难度: ⭐⭐⭐⭐
当应用程序在开发模式下运行时,React 将自动检查咱们在组件上设置的所有 props
,以确保它们具有正确的数据类型。对于不正确的类型,开发模式下会在控制台中生成警告消息,而在生产模式中由于性能影响而禁用它。强制的 props
用 isRequired
定义的。
下面是一组预定义的 prop 类型:
例如,咱们为用户组件定义了如下的propTypes
import PropTypes from 'prop-types'; class User extends React.Component { render() { return ( <h1>Welcome, {this.props.name}</h1> <h2>Age, {this.props.age} ); } } User.propTypes = { name: PropTypes.string.isRequired, age: PropTypes.number.isRequired };
主题: React
难度: ⭐⭐⭐⭐
构造函数和getInitialState
之间的区别就是ES6
和ES5
本身的区别。在使用ES6
类时,应该在构造函数中初始化state
,并在使用React.createClass
时定义getInitialState
方法。
class MyComponent extends React.Component { constructor(props) { super(props); this.state = { /* initial state */ }; } }
等价于:
var MyComponent = React.createClass({ getInitialState() { return { /* initial state */ }; }, });
主题: React
难度: ⭐⭐⭐⭐
对于某些属性,React 非常聪明,如果传递给它的值是虚值,可以省略该属性。例如:
var InputComponent = React.createClass({ render: function() { var required = true; var disabled = false; return ( <input type="text" disabled={disabled} required={required} /> ); } });
渲染结果:
<input type="text" required>
另一种可能的方法是:
var condition = true; var component = ( <p value="foo" { ...( condition && { disabled: true } ) } /> );
render props
和高阶组件吗?主题: React
难度: ⭐⭐⭐⭐
通常,render props
和高阶组件仅渲染一个子组件。React团队认为,Hooks 是服务此用例的更简单方法。
这两种模式仍然有一席之地(例如,一个虚拟的 scroller
组件可能有一个 renderItem prop
,或者一个可视化的容器组件可能有它自己的 DOM 结构)。但在大多数情况下,Hooks 就足够了,可以帮助减少树中的嵌套。
主题: React
难度: ⭐⭐⭐⭐
React 中最常见的问题之一是组件不必要地重新渲染。React 提供了两个方法,在这些情况下非常有用:
React.memo()
:这可以防止不必要地重新渲染函数组件PureComponent
:这可以防止不必要地重新渲染类组件这两种方法都依赖于对传递给组件的props
的浅比较,如果 props
没有改变,那么组件将不会重新渲染。虽然这两种工具都非常有用,但是浅比较会带来额外的性能损失,因此如果使用不当,这两种方法都会对性能产生负面影响。
通过使用 React Profiler,可以在使用这些方法前后对性能进行测量,从而确保通过进行给定的更改来实际改进性能。
主题: React
难度: ⭐⭐⭐⭐⭐
纯函数是不依赖并且不会在其作用域之外修改变量状态的函数。本质上,纯函数始终在给定相同参数的情况下返回相同结果。
setState
时,React render
是如何工作的?主题: React
难度: ⭐⭐⭐⭐⭐
咱们可以将"render
"分为两个步骤:
render
方法被调用时,它返回一个新的组件的虚拟 DOM 结构。当调用setState()
时,render
会被再次调用,因为默认情况下shouldComponentUpdate
总是返回true
,所以默认情况下 React 是没有优化的。主题: React
难度: ⭐⭐⭐⭐⭐
有几种常用方法可以避免在 React 中绑定方法:
1.将事件处理程序定义为内联箭头函数
class SubmitButton extends React.Component { constructor(props) { super(props); this.state = { isFormSubmitted: false }; } render() { return ( <button onClick={() => { this.setState({ isFormSubmitted: true }); }}>Submit</button> ) } }
2.使用箭头函数来定义方法:
class SubmitButton extends React.Component { state = { isFormSubmitted: false } handleSubmit = () => { this.setState({ isFormSubmitted: true }); } render() { return ( <button onClick={this.handleSubmit}>Submit</button> ) } }
3.使用带有 Hooks 的函数组件
const SubmitButton = () => { const [isFormSubmitted, setIsFormSubmitted] = useState(false); return ( <button onClick={() => { setIsFormSubmitted(true); }}>Submit</button> ) };
本文转载自:https://segmentfault.com/a/1190000020912300
相关教程推荐:React视频教程
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!