What is the mental model of redux-saga?

  • Asynchronous call stack
  • Finite state machine
  • Observer pattern
The mental model of redux-saga is that of a finite state machine. It allows you to define a sequence of steps for handling a specific side effect and provides a way to manage the state of that sequence. This makes it easier to reason about and test complex logic in your Redux application.

How do you conditionally render components?

  • Use the "if" statement in JSX
  • Use the "render" method in JSX
  • Use the switch statement in JSX
  • Use the ternary operator in JSX
To conditionally render components in React, you can use the ternary operator in JSX. This allows you to specify a condition, and render one component if the condition is true, and another component if the condition is false. You can also use other conditional statements, such as "if" statements or switch statements, outside of the JSX to determine which component to render.

What is a consumer?

  • A component that provides a context value
  • A component that consumes a context value
  • A component that renders children conditionally
  • A component that handles user events
In React context, a consumer is a component that consumes a context value. The consumer component allows child components to access the context value without the need to pass props explicitly. Consumers can be implemented using the useContext() hook or the Consumer component, which provides a render prop that can be used to consume the context value.

What is Formik?

  • A React library for working with forms
  • A testing library for React
  • A utility library for working with arrays
  • An animation library for React
Formik is a utility library for working with forms in React. It provides a simple and flexible way to handle form validation, input masking, and submission handling. Formik also integrates with other popular form libraries, such as Yup and React-Select.

What are React Mixins?

  • Components that are composed of other components
  • Methods for handling async operations in React
  • Reusable code snippets that can be applied to multiple components
  • Techniques for improving the performance of React applications
React Mixins are reusable code snippets that can be applied to multiple components in order to provide shared functionality. They are a way to encapsulate logic and behavior that can be used across multiple components, allowing for code reuse and reducing duplication. However, they are not recommended in modern versions of React and have been largely replaced by higher-order components and render props.

How Redux Form initialValues get updated from state?

  • initialValues are automatically synced with the Redux store
  • You need to manually update initialValues in the form component
  • initialValues are passed in as a prop to the form component
The initialValues prop in Redux Form is used to set the initial values for the form fields. You can pass in an object of initial values as the initialValues prop, which will be used to populate the form fields when the form is first rendered. The initialValues can be sourced from the Redux store, and can be updated by dispatching an action that updates the relevant values in the store. The form component will automatically update when the initialValues prop changes.

What is a switching component?

  • A component that animates between different states
  • A component that changes its state based on user input
  • A component that provides an interface for switching between different pages
  • A component that switches between multiple child components
A switching component in React is a component that renders one of several child components based on some condition or state. This is commonly used to switch between different views or user interface elements in response to user input or other events.

What is the purpose of ReactTestUtils package?

  • To generate test data
  • To mock HTTP requests
  • To simulate component rendering without deep rendering
  • To test React components
The ReactTestUtils package provides a set of utilities for testing React components. It allows developers to simulate events, perform component rendering, and find components in the rendered output. It is commonly used in combination with Jest or another testing framework.

Does React support all HTML attributes?

  • Yes, React supports all HTML attributes
  • No, React only supports a subset of HTML attributes
React supports a subset of HTML attributes, as not all attributes are applicable or relevant to React components. Some HTML attributes, such as "class" and "for", are reserved words in JavaScript and cannot be used directly in JSX. Instead, React uses the "className" and "htmlFor" attributes, respectively. Additionally, some HTML attributes may have different names or syntax in React, such as "tabindex" being spelled "tabIndex" in React.

What is the purpose of the constants in Redux?

  • To make the code easier to read and understand
  • To prevent changes to the action types
  • To enable minification and other performance optimizations
Constants in Redux are used to define action types, which are used to identify the type of action being dispatched to the Redux store. By using constants, you can prevent unintended changes to the action types and make it easier to understand the purpose of each action.