服务器之家:专注于服务器技术及软件下载分享
分类导航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服务器之家 - 编程语言 - JavaScript - React - React事件节流效果失效的原因及解决

React事件节流效果失效的原因及解决

2022-03-06 21:27Cleves React

这篇文章主要介绍了React事件节流效果失效的原因及解决,帮助大家更好的理解和学习使用React框架,感兴趣的朋友可以了解下

今天做react项目中,给一个 input onKeyDown 事件做节流,出现了节流效果失效。

问题代码:

?
1
2
3
4
5
6
7
render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="请输入要搜索的用户名(英文)" onKeyDown={this.throttle(this.handleKeyDown)}/>
      </div>
    )
  }
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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
    
    // 发送搜索
    this.props.search(value)
  }

此处问题出现在: 

handleKeyDown() 方法里的  this.props.search(value)
 刷新了组件 props,触发了 react 更新流生命周期。 重新执行了 render();

React事件节流效果失效的原因及解决

这样 throttle() 方法就会重新执行; 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
throttle = (fn) => {
    console.log('%c throttle初始化', '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);
    }
  }

在代码中加入打印,就会在控制台看到 throttle初始化 打印多条;                                                                                                                                                            

解决方式1: 

把节流初始化的位置放到 事件函数赋值

?
1
2
3
4
5
6
7
render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="请输入要搜索的用户名(英文)" onKeyDown={this.handleKeyDown}/>
      </div>
    )
  }
?
1
2
3
4
5
6
7
8
9
10
11
handleKeyDown = this.throttle((e) => {
    let { value } = e.target
    const keyCode = e.keyCode
 
    if (keyCode !== 13) return
 
    if (!value.trim()) return
    
    // 发送搜索
    this.props.search(value)
  })

解决方式2: 在构造函数中赋值初始化

?
1
2
3
4
5
6
7
render() {
    return (
      <div className="search-bar">
        <input className="search-input" type="text" placeholder="请输入要搜索的用户名(英文)" onKeyDown={this.handleKeyDown}/>
      </div>
    )
  }
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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
    
    // 发送搜索
    this.props.search(value)
  }

采坑总结:

要更加深了解 react 生命周期的触发机制

以上就是React事件节流效果失效的原因及解决的详细内容,更多关于React事件节流效果失效的资料请关注服务器之家其它相关文章!

原文链接:https://www.cnblogs.com/cleves/p/14663672.html

延伸 · 阅读

精彩推荐
  • ReactReact useEffect的理解与使用

    React useEffect的理解与使用

    这篇文章主要介绍了React useEffect的理解与使用,帮助大家更好的理解和学习使用React,感兴趣的朋友可以了解下...

    RedCHr5302022-03-06
  • React基于 Vite 的组件文档编写神器,又快又省心

    基于 Vite 的组件文档编写神器,又快又省心

    现在 Vite 的生态逐渐完善,今天给大家介绍一款 React 的组件/应用文档编写神器:vite-plugin-react-pages....

    前端星辰5132022-01-04
  • ReactReact html中使用react的两种方式

    React html中使用react的两种方式

    这篇文章主要介绍了React html中使用react的两种方式,本文给大家提到了React pwa的配置代码,给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴...

    愚公搬代码6362022-02-23
  • React简单分析React中的EffectList

    简单分析React中的EffectList

    这篇文章主要简单分析了React中的EffectList,帮助大家更好的理解和学习使用React进行前端开发,感兴趣的朋友可以了解下...

    zhangyu8232022-02-24
  • Reactreact-native 实现购物车滑动删除效果的示例代码

    react-native 实现购物车滑动删除效果的示例代码

    这篇文章主要介绍了react-native 实现购物车滑动删除效果的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    程序猿tx3892021-12-31
  • ReactReact服务端渲染原理解析与实践

    React服务端渲染原理解析与实践

    这篇文章主要介绍了React服务端渲染原理解析与实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们...

    隐冬8032022-02-10
  • React聊一聊我对 React Context 的理解以及应用

    聊一聊我对 React Context 的理解以及应用

    这篇文章主要介绍了聊一聊我对 React Context 的理解以及应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    张国钰6572022-02-24
  • ReactReact 三大属性之state的使用详解

    React 三大属性之state的使用详解

    这篇文章主要介绍了React 三大属性之state的使用详解,帮助大家更好的理解和学习使用React,感兴趣的朋友可以了解下...

    xiaoznz3702022-03-02