返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React事件监听和State状态修改方式
  • 539
分享到

React事件监听和State状态修改方式

React事件监听State状态修改React监听事件 2022-11-13 14:11:27 539人浏览 独家记忆
摘要

目录React事件监听和State状态修改React事件监听相关例子React事件监听和State状态修改 on*函数可直接使用,但只能使用在html标签上,自己创建的组件标签不可

React事件监听和State状态修改

on*函数可直接使用,但只能使用在html标签上,自己创建的组件标签不可

组件可以增加state状态,修改用setState方法,修改会有缓存,只能保证在渲染到页面之前会改好。所以setState后立马去使用值可能是不对的

狗子组件1:点击会打印bark和run

class Dog extends Component {
  bark () {
    console.log('bark')
  }
  
  run () {
    console.log('run')
  }
  
  render () {
    return (<div onClick={
    //有两个方法需要实现,所以用一个函数进行封装
      ()=>{
        this.bark();
        this.run();
      }
    }>DOG</div>)
    }
}
ReactDOM.render(<Dog/>,document.querySelector('#root'));

狗子组件2:增加bark和run状态,开始为false,点击变成true,1s后还原成false 

class Dog extends Component {
  constructor () {
    super()
    this.state={
      bark:false,
      run:false
    }
  }
  
  clickYeah () {
    this.setState({
      bark: true,
      run: true
    })
    //因为setState会有缓存,值后面才会变,所以这里打印出来还是false
    console.log('bark'+this.state.bark);
    console.log('run'+this.state.run);
    setTimeout(()=>{
      //1s之后将值改回成false,所以这里打印出来还是false。如果想要检验前面修改成true有没有生效,可以将这里setState修改成false的步骤先注释掉
      this.setState({
        bark: false,
        run: false
      })
      console.log('bark'+this.state.bark+'run'+this.state.run);
    },1000)
  }
  
  render () {
    return (<div onClick={this.clickYeah.bind(this)}>DOG</div>)
  }
}
ReactDOM.render(<Dog/>,document.querySelector('#root'));

React事件监听相关例子

 var TestClickComponent = React.creatsClass({
    handleClick: function(event){
 
    //操作DOM节点
 
        var msg = React.findDOMnode(this.refs.tip);
         if(msg.style.display === 'none'){
            msg.style.display = 'inline';
        }else{
            msg.style.display = 'none';
        }
        //阻止事件的冒泡和默认行为
 
        event.stopPropagation();
        event.preventDefault();
    },
 
    render: function(){
 
        return(
            <div>
                <button onClick={this.handleClick}>显示/隐藏</button>
                <span ref="tip">message</span>
            </div>
        );
    }
});
var TestInputComponent = React.createClass({
    getInitialState: function(){
        return{
            inputContent: ' '
        }
    },
 
    changeHandler:function(event){
 
      //改变state的值
 
        this.setState({
            inputContent:event,target.value
        });
 
        event.preventDefault();
        event.stopPropagation();
    },
 
    render: function(){
 
        return(
            <div>
                <input type="text" onChange={this.changeHandler}/>
                <span>{this.state.inputContent}</span>
            </div>
        ); 
    } 
});

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: React事件监听和State状态修改方式

本文链接: https://lsjlt.com/news/171763.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • React事件监听和State状态修改方式
    目录React事件监听和State状态修改React事件监听相关例子React事件监听和State状态修改 on*函数可直接使用,但只能使用在html标签上,自己创建的组件标签不可 ...
    99+
    2022-11-13
    React事件监听 State状态修改 React 监听事件
  • React在组件中如何监听redux中state状态的改变
    目录在组件中监听redux中state状态的改变解决方式React和redux的状态处理在组件中监听redux中state状态的改变 解决方式 1、在组件中引入store 2、在co...
    99+
    2022-11-13
    React组件 监听state的改变 监听redux中state改变
  • JavaScript注册监听事件和清除监听事件方式详解
    目录前言注册监听事件传统方式方法监听事件注册方式addEventListener()attachEvent()addEventListener()与attachEvent()的兼容移...
    99+
    2023-05-19
    js注册监听事件和清除事件 js清除事件监听 js监听刷新事件
  • react中如何修改组件状态
    本篇内容介绍了“react中如何修改组件状态”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • Spring事件发布监听,顺序监听,异步监听方式
    目录1. Spring的事件通知2. Spring事件通知使用2.1 Spring的事件2.2 事件监听2.2.1 接口方式实现2.2.2 注解实现2.3 事件发布2.4 Sprin...
    99+
    2024-04-02
  • React中DOM事件和状态介绍
    目录DOM事件参数作用域状态无状态组件有状态组件使用状态数据初始化状态数据修改状态数据DOM事件 react中绑定事件的语法跟html中为元素绑定事件的语法相似, html中绑定事件...
    99+
    2024-04-02
  • jQuery如何监听浏览器在线状态事件?
    这篇文章将为大家详细讲解有关jQuery如何监听浏览器在线状态事件?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jQuery 监听浏览器在线状态事件 前言 浏览器在线状态事件是当浏览器与互联网之间的连接...
    99+
    2024-04-02
  • jQuery如何监听浏览器离线状态事件?
    这篇文章将为大家详细讲解有关jQuery如何监听浏览器离线状态事件?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jQuery 监听浏览器离线状态事件 jQuery 提供了一种机制来监听浏览器离线状态事件...
    99+
    2024-04-02
  • jquery事件监听的方式有哪些
    本篇内容主要讲解“jquery事件监听的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“jquery事件监听的方式有哪些”吧! ...
    99+
    2024-04-02
  • Android编程监听网络连接状态改变的方法
    本文实例讲述了Android编程监听网络连接状态改变的方法。分享给大家供大家参考,具体如下:BroadcastReceiverpublic class MyReceiver extends BroadcastReceiver { @Ove...
    99+
    2023-05-31
    android 监听 网络连接
  • Android中检查、监听电量和充电状态的方法
    当你在更改后台更新频率来减少这些更新对电池寿命的影响时,检查当前电量和充电状态是一个好的开始。 电池寿命通过剩余电量和充电状态来影响应用更新的执行。当用交流电充电时,执行更新操...
    99+
    2022-06-06
    监听 方法 Android
  • jQuery3种常见事件监听方式是什么
    这篇文章主要为大家展示了“jQuery3种常见事件监听方式是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jQuery3种常见事件监听方式是什么”这篇文章吧。1.HTML标签内联事件实例1:...
    99+
    2023-06-29
  • Android判断和监听底座状态和类型的方法介绍
    底座的状态跟充电状态类似,很多底座提供充电功能(座充). 底座状态同样使用sticky Intent广播。可以查询设备是否插入底座,哪种底座。 判断当前底座状态 广播的Acti...
    99+
    2022-06-06
    监听 方法 Android
  • 微信小程序如何监听蓝牙适配器状态变化事件
    这篇“微信小程序如何监听蓝牙适配器状态变化事件”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“微信小程序如何监听蓝牙适配器状态变化事件”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇...
    99+
    2023-06-26
  • 分享jQuery的3种常见事件监听方式
    目录1.HTML标签内联事件2.用JavaScript实现事件监听3.用jQuery实现事件监听前言: 在 Web 页面经常会有各种事件发生,事件发生后需要进行一些特定处理,即执行特...
    99+
    2024-04-02
  • Spring的事件发布与监听方式是什么
    本篇内容介绍了“Spring的事件发布与监听方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事件主要代码在org.springfra...
    99+
    2023-07-05
  • 关于React动态修改元素样式的三种方式
    目录React动态修改元素样式1.借助ref动态修改样式2.通过动态控制状态的变化修改元素的样式(两种方式)3.通过在DOM中使用JS代码(三元运算符)React样式冲突问题css-...
    99+
    2022-11-13
    React动态修改样式 React元素样式 元素样式动态修改
  • React中使用事件驱动进行状态管理的方法
    这篇文章给大家分享的是有关React中使用事件驱动进行状态管理的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。自 Hook 被引入 React  以来,Context API 与 Hook 库在应用...
    99+
    2023-06-14
  • Spring boot+LayIM + t-io如何实现文件上传和监听用户状态
    小编给大家分享一下Spring boot+LayIM + t-io如何实现文件上传和监听用户状态,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!springboot...
    99+
    2023-05-30
    springboot layim
  • Android实现的状态栏定制和修改方法
    本文实例讲述了Android实现的状态栏定制和修改方法。分享给大家供大家参考。具体如下: 大家都知道定制在android开发中的重要性,因为通过定制,你才能制造出差异化的产品,...
    99+
    2022-06-06
    方法 状态栏 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作