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 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 constructorrender() { 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:
|
<<: Examples of optimization techniques for slow query efficiency in MySQL IN statements
>>: Explanation of Linux kernel optimization configuration for high-concurrency nginx server
1. Take nginx as an example Nginx installed using...
Table of contents Preface introduce 1. Mechanism ...
1. Prepare data The following operations will be ...
Enter the /etc/yum.repos.d/ folder Create rabbitm...
Nginx supports three ways to configure virtual ho...
Preface Node will be used as the middle layer in ...
The first step is to download the free installati...
In the process of learning web design, I did not ...
This article describes the VMware virtual machine...
question Adding the type of uploaded file in acce...
Preface I recently made a fireworks animation, wh...
IIS7 Download the HTTP Rewrite module from Micros...
This article example shares the specific code of ...
Table of contents 1 Indicators in stress testing ...
This article analyzes the consistency processing ...