Home >Web Front-end >JS Tutorial >What questions will be asked during the react interview? Detailed analysis and answers to common react interview questions

What questions will be asked during the react interview? Detailed analysis and answers to common react interview questions

寻∝梦
寻∝梦Original
2018-09-11 14:03:492329browse

This article mainly introduces the analysis of common problems in react. There are questions and answers. Click here to see if one of the questions can help you solve your doubts. Let us read this article now

1. What is the difference between Element and Component in React?

The official website document explains Element as:

Elements are the smallest building blocks of React apps.
An element describes what you want to see on the screen:

The official website explains Compent as:

Components let you split the UI into independent, reusable pieces, and think about each piece in isolation.
Conceptually, components are like JavaScript functions. They accept arbitrary inputs (called "props") and return React elements describing what should appear on the screen.

In other words, React Element describes what is seen on the screen. The data structure of the content is the object representation of the UI. A typical React Element is a declarative code piece built using JSX and then converted into a combination of createElement calls. React Component is a function or class that can receive parameter input and return a React Element.

2. JSX

React uses JSX to replace regular JavaScript. JSX is a JavaScript syntax extension that looks a lot like XML. We don't necessarily need to use JSX, but it has the following advantages:

JSX 执行更快,因为它在编译为 JavaScript 代码后进行了优化。
它是类型安全的,在编译过程中就能发现错误。
使用 JSX 编写模板更加简单快速。

3. What happens after calling setState?

After calling the setState function in the code, React will merge the passed parameter object with the current state of the component, and then trigger the so-called reconciliation process (Reconciliation). After the reconciliation process, React will build the React element tree based on the new state in a relatively efficient way and proceed to re-render the entire UI interface. After React obtains the element tree, React will automatically calculate the node difference between the new tree and the old tree, and then minimize and re-render the interface based on the difference. In the difference calculation algorithm, React can relatively accurately know which positions have changed and how they should be changed, which guarantees on-demand updates instead of full re-rendering.

4. Under what circumstances would you prefer to use Class Component instead of Functional Component?

Use Class Component when the component needs to contain internal state or use life cycle functions, otherwise use functional components.

5. At which step in the life cycle should you initiate an AJAX request?

We should put the AJAX request in the componentDidMount function for the following reasons:

React's next-generation reconciliation algorithm Fiber will optimize application performance by starting or stopping rendering. It will affect the number of triggers of componentWillMount. The number of calls to the componentWillMount lifecycle function becomes uncertain, and React may call componentWillMount multiple times and frequently. If we put the AJAX request in the componentWillMount function, then it will obviously be triggered multiple times, which is naturally not a good choice.

If we place the AJAX request in other functions of the life cycle, we cannot guarantee that the request will only require a response after the component is mounted. If our data request is completed before the component is mounted, and the setState function is called to add data to the component state, an error will be reported for the unmounted component. Making AJAX requests in the componentDidMount function can effectively avoid this problem. (If you want to learn more, go to the PHP Chinese website React Reference Manual column to learn)

6. What is the difference between Controlled Component and Uncontrolled Component?

One of the core components of React is autonomous components that can maintain internal state. However, when we introduce native HTML form elements (input, select, textarea, etc.), should we put all the data Host it into a React component or keep it in a DOM element? The answer to this question is the definitional separation of controlled and uncontrolled components. Controlled Component refers to components that are controlled by React and all form data is stored uniformly. In other words, if the value values ​​of elements such as 73a3ca28445b1c625f2086a50cb8c7df, 61d90be9d2f4c66acf53b3eb6fb9f09d, 9c8501ef49561f01c98856a0e886b175 in React.js are controlled by React.js, then It is a controlled component. For example, in the following code, the username variable value is not stored in the DOM element, but is stored in the component status data. Any time we need to change the value of the username variable, we should call the setState function to modify it.

class ControlledForm extends Component {
  state = {
    username: ''
  }
  updateUsername = (e) => {    this.setState({
      username: e.target.value,
    })
  }
  handleSubmit = () => {}
  render () {    return (
      <form onSubmit={this.handleSubmit}>
        <input          type=&#39;text&#39;
          value={this.state.username}
          onChange={this.updateUsername} />
        <button type=&#39;submit&#39;>Submit</button>
      </form>
    )
  }
}

Uncontrolled Component stores form data in the DOM, not in the React component. We can use refs to manipulate DOM elements:

class UnControlledForm extends Component {
  handleSubmit = () => {
    console.log("Input Value: ", this.input.value)
  }
  render () {    return (
      <form onSubmit={this.handleSubmit}>
        <input          type=&#39;text&#39;
          ref={(input) => this.input = input} />
        <button type=&#39;submit&#39;>Submit</button>
      </form>
    )
  }
}

Unexpectedly, uncontrolled components look better to implement. We can grab data directly from the DOM without adding additional code. However, we do not advocate the use of uncontrolled components in actual development, because in actual situations we need to consider more functional support such as form validation, selectively turning on or off button clicks, and forced input formats. At this time, we will host the data Into React helps us better complete these functions in a declarative manner. The original reason for introducing React or other MVVM frameworks is to free us from the heavy direct manipulation of the DOM.

7. What is the function of shouldComponentUpdate and why is it so important?

shouldComponentUpdate 允许我们手动地判断是否要进行组件更新,根据组件的应用场景设置函数的合理返回值能够帮我们避免不必要的更新。

8、概述下 React 中的事件处理逻辑

为了解决跨浏览器兼容性问题,React 会将浏览器原生事件(Browser Native Event)封装为合成事件(SyntheticEvent)传入设置的事件处理器中。这里的合成事件提供了与原生事件相同的接口,不过它们屏蔽了底层浏览器的细节差异,保证了行为的一致性。另外有意思的是,React 并没有直接将事件附着到子元素上,而是以单一事件监听器的方式将所有的事件发送到顶层进行处理。这样 React 在更新 DOM 的时候就不需要考虑如何去处理附着在 DOM 上的事件监听器,最终达到优化性能的目的。

9、传入 setState 函数的第二个参数的作用是什么?

该函数会在setState函数调用完成并且组件开始重渲染的时候被调用,我们可以用该函数来监听渲染是否完成:

this.setState(
  { username: &#39;tylermcginnis33&#39; },  () => console.log(&#39;setState has finished and the component has re-rendered.&#39;)
)

10、组件的生命周期

组件的生命周期分成三个状态:

Mounting:已插入真实 DOM
Updating:正在被重新渲染
Unmounting:已移出真实 DOM

React 为每个状态都提供了两种处理函数,will 函数在进入状态之前调用,did 函数在进入状态之后调用,三种状态共计五种处理函数。

componentWillMount()componentDidMount()componentWillUpdate(object nextProps, object nextState)componentDidUpdate(object prevProps, object prevState)componentWillUnmount()

此外,React 还提供两种特殊状态的处理函数。

componentWillReceiveProps(object nextProps):已加载组件收到新的参数时调用shouldComponentUpdate(object nextProps, object nextState):组件判断是否重新渲染时调用

本篇文章到这就结束了(想看更多就到PHP中文网React使用手册栏目中学习),有问题的可以在下方留言提问。

The above is the detailed content of What questions will be asked during the react interview? Detailed analysis and answers to common react interview questions. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn