React.js
What is React?
Created by Facebook, React is a declarative, efficient, and flexible front end JavaScript framework for building user interfaces. It lets you compose complex UIs from small and isolated pieces of code called "components".
How does React work?
React creates a virtual DOM. When state changes in a component it firstly runs a "diffing" algorithm, which identifies what has changed in the virtual DOM. The second step is reconciliation, where it updates the DOM with the results of diff.
What are the advantages of using React?
What is the difference between a Presentational component and a Container component?
Presentational components are concerned with how things look. They generally receive data and callbacks exclusively via props. These components rarely have their own state, but when they do it generally concerns UI state, as opposed to data state.
Container components are more concerned with how things work. These components provide the data and behavior to presentational or other container components. They call Flux actions and provide these as callbacks to the presentational components. They are also often stateful as they serve as data sources.
What are the differences between a class component and functional component?
What is the difference between state and props?
The state is a data structure that starts with a default value when a Component mounts. It may be mutated across time, mostly as a result of user events.
Props (short for properties) are a Component's configuration. They are received from above and immutable as far as the Component receiving them is concerned. A Component cannot change its props, but it is responsible for putting together the props of its child Components. Props do not have to just be data - callback functions may be passed in as props.
Name the different lifecycle methods
Where in a React component should you make an AJAX request?
componentDidMount is where an AJAX request should be made in a React component. This method will be executed when the component “mounts” (is added to the DOM) for the first time. This method is only executed once during the component’s life.
Importantly, we can’t guarantee the AJAX request will have resolved before the component mounts. If it doesn't, that would mean that we'd be trying to setState on an unmounted component, which would not work. Making our AJAX request in componentDidMount will guarantee that there’s a component to update.
What are controlled components?
In HTML, form elements such as <input> , <textarea> , and <select> typically maintain their own state and update it based on user input. When a user submits a form the values from the aforementioned elements are sent with the form.
With React, it works differently. The component containing the form will keep track of the value of the input in it's state and will re-render the component each time the callback function e.g. onChange is fired as the state will be updated. An input form element whose value is controlled by React in this way is called a "controlled component".
What are refs used for in React?
Refs are used to get reference to a DOM node or an instance of a component in React. Good examples of when to use refs are for managing focus/text selection, triggering imperative animations, or integrating with third-party DOM libraries. We should avoid using string refs and inline ref callbacks. Callback refs are advised by React.
What is a higher order component?
A higher-order component is a function that takes a component and returns a new component. HOC's allow code reuse, logic and bootstrap abstraction. The most common is probably Redux’s connect function. Beyond simply sharing utility libraries and simple composition, HOCs are the best way to share behavior between React Components. If we find ourself writing a lot of code in different places that does the same thing, we may be able to refactor that code into a reusable HOC.
What advantages are there in using arrow functions?
Why is it advised to pass a callback function to setState as opposed to an object?
Because this.props and this.state may be updated asynchronously, we should not rely on their values for calculating the next state.
What is the alternative of binding this in the constructor?
One can use property initializers to correctly bind callbacks. This is enabled by default in create react app. An arrow function could be used in the callback but the problem would be that a new callback gets created each time the component renders.
How would you prevent a component from rendering?
Returning null from a component's render method means nothing will be displayed, but it does not affect the firing of the component's lifecycle methods.
If the amount of times the component re-renders is an issue, there are two options available. Manually implementing a check in shouldComponentUpdate lifecycle method hook.
shouldComponentUpdate (nProps, nState){
// Do some check here
return resultOFCheckAsBoolean
}
Or using React.PureComponent instead of React.Component React.PureComponent implements shouldComponentUpdate() with a shallow prop and state comparison. This avoid re-rendering the component with the same props and state.
When rendering a list what is a key and what is it's purpose?
Keys help React identify which items have changed, are added, or are removed. Keys should be given to the elements inside the array to give the elements a stable identity. The best way to pick a key is to use a string that uniquely identifies a list item among its siblings.
Most often one would use IDs from the data as keys. When we don't have stable IDs for rendered items, we may use the item index as a key as a last resort. It is not recommend to use indexes for keys if the items can reorder.
What is the purpose of super(props)?
A child class constructor cannot make use of this until super() has been called. Also, ES2015 class constructors have to call super() if they are subclasses. The reason for passing props to super() is to enable access to this.props in the constructor.
What is JSX?
JSX is a syntax extension to JavaScript and comes with the full power of JavaScript. JSX produces React "elements". One can embed any JavaScript expression in JSX by wrapping it in curly braces. After compilation, JSX expressions become regular JavaScript objects. This means that we can use JSX inside if statements and for loops, assign it to variables, accept it as arguments, and return it from functions.
What is equivalent of the following using React.createElement?
const element =
< h1 className= "greeting" >
Hello, world!
</h1>;
Answer
const element =
React .createElement (
'h1' ,
{ className : 'greeting' },
'Hello, world!'
) ;
What is Children ?
In JSX expressions that contain both an opening tag and a closing tag, the content between those tags is passed to components automatically as a special prop: props.children .
There are a number of methods available in the React API to work with this prop . These include React.Children.map , React.Children.forEach , React.Children.count , React.Children.only , React.Children.toArray .
What is state in react?
State is similar to props, but it is private and fully controlled by the component. State is essentially an object that holds data and determines how the component renders and behaves.
What is redux?
The basic idea of redux is that the entire application state is kept in a single store. The store is simply a JavaScript object. The only way to change the state is by firing actions from your application and then writing reducers for these actions that modify the state. The entire state transition is kept inside reducers and should not have any side-effects.
What is a store in redux?
The store is a JavaScript object that holds the application state. Along with this it also has the following responsibilities:
What is an action?
Actions are plain JavaScript objects. They must have a type indicating the type of action being performed. In essence, actions are payloads of information that send data from your application to your store.
What is a reducer?
A reducer is simply a pure function that takes the previous state and an action, and returns the next state.
What is Redux Thunk used for?
Redux thunk is middleware that allows writing action creators that return a function instead of an action. The thunk can then be used to delay the dispatch of an action if a certain condition is met. This allows handling the asynchronous dispatching of actions.
What is a pure function?
A pure function is a function that doesn't depend on and doesn't modify the states of variables out of its scope. Essentially, this means that a pure function will always return the same result when given the same input parameters.