Reasons and solutions for the failure of React event throttling effect

Reasons and solutions for the failure of React event throttling effect

Today, when I was working on a react project, I throttled an input onKeyDown event, but the throttling effect failed.

Problem code:

render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="Please enter the user name to search (English)" onKeyDown={this.throttle(this.handleKeyDown)}/>
      </div>
    )
  }
throttle = (fn) => {
    let valid = true
    const context = this

    return function() {
      if (!valid) return
      valid = false

      const args = arguments

      fn.apply(context, args)

      setTimeout(() => {
        valid = true
      }, 1000);
    }
  }

  handleKeyDown = (e) => {
    let { value } = e.target
    const keyCode = e.keyCode

    if (keyCode !== 13) return

    if (!value.trim()) return
    
    // Send search this.props.search(value)
  }

The problem here is:

this.props.search(value) in handleKeyDown() method
The component props are refreshed, triggering the react update flow lifecycle. Re-executed render();

In this way, the throttle() method will be re-executed;

throttle = (fn) => {
    console.log('%c throttle initialization', 'color: red');
    let valid = true
    const context = this

    return function() {
      if (!valid) return
      valid = false

      const args = arguments

      fn.apply(context, args)

      setTimeout(() => {
        valid = true
      }, 1000);
    }
  }

If you add printing to the code, you will see throttle initialization print multiple lines in the console;

Solution 1:

Put the throttling initialization position into the event function assignment

render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="Please enter the user name to search (English)" onKeyDown={this.handleKeyDown}/>
      </div>
    )
  }
handleKeyDown = this.throttle((e) => {
    let { value } = e.target
    const keyCode = e.keyCode

    if (keyCode !== 13) return

    if (!value.trim()) return
    
    // Send search this.props.search(value)
  })

Solution 2: Assign initialization in the constructor

render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="Please enter the user name to search (English)" onKeyDown={this.handleKeyDown}/>
      </div>
    )
  }
constructor(props) {
    super(props)
    this.handleKeyDown = this.throttle(this.handleSearch)
  }

  handleSearch = (e) => {
    let { value } = e.target
    const keyCode = e.keyCode

    if (keyCode !== 13) return

    if (!value.trim()) return
    
    // Send search this.props.search(value)
  }

Summary of mining pits:

To better understand the triggering mechanism of the react life cycle

The above is the detailed content of the reasons and solutions for the failure of React event throttling effect. For more information about the failure of React event throttling effect, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • How to introduce scss into react project
  • How to introduce Angular components in React
  • React introduces container components and display components to Vue
  • React internationalization react-intl usage
  • React Synthetic Events Explained
  • A brief comparison of Props in React
  • Detailed explanation of the solution for migrating antd+react projects to vite
  • React implementation example using Amap (react-amap)
  • A brief introduction to React

<<:  Examples of optimization techniques for slow query efficiency in MySQL IN statements

>>:  Explanation of Linux kernel optimization configuration for high-concurrency nginx server

Recommend

Nginx server adds Systemd custom service process analysis

1. Take nginx as an example Nginx installed using...

Detailed examples of the difference between methods watch and computed in Vue.js

Table of contents Preface introduce 1. Mechanism ...

MySQL single table query example detailed explanation

1. Prepare data The following operations will be ...

Tutorial on installing rabbitmq using yum on centos8

Enter the /etc/yum.repos.d/ folder Create rabbitm...

Three ways to configure Nginx virtual hosts (based on domain names)

Nginx supports three ways to configure virtual ho...

How to deploy Node.js with Docker

Preface Node will be used as the middle layer in ...

MySQL 8.0.23 free installation version configuration detailed tutorial

The first step is to download the free installati...

How to configure VMware virtual machine NAT mode

This article describes the VMware virtual machine...

Solution to Element-ui upload file upload restriction

question Adding the type of uploaded file in acce...

Understanding the CSS transform-origin property

Preface I recently made a fireworks animation, wh...

IIS and APACHE implement HTTP redirection to HTTPS

IIS7 Download the HTTP Rewrite module from Micros...

JavaScript implements double-ended queue

This article example shares the specific code of ...

Server stress testing concepts and methods (TPS/concurrency)

Table of contents 1 Indicators in stress testing ...

Analyze Mysql transactions and data consistency processing issues

This article analyzes the consistency processing ...