React之回调ref中回调执行次数的问题
<!DOCTYPE html>
<html>
<head>
<meat charset="UTF-8">
<title>3_回调ref中回调执行次数的问题</title>
</head>
<body>
<!-- 准备好一个容器 -->
<div id="test"></div>
<!-- 核心库 -->
<script type="text/javascript" src="../js/react.development.js"></script>
<!-- react-dom,操作dom -->
<script type="text/javascript" src="../js/react-dom.development.js"></script>
<!-- 引入babel,jsx转为js -->
<script type="text/javascript" src="../js/babel.min.js"></script>
<!-- 此处一定要写babel -->
<script type="text/babel">
//1.创建组件
class Demo extends React.Component{
state = {isHot:true}
showInfo = ()=>{
const {input1} = this
alert(input1.value)
}
changeWeather = ()=>{
//获取原来的状态
const {isHot} = this.state
//更新状态
this.setState({isHot:!isHot})
}
saveInput = (c) =>{
this.input1 = c;
console.log('@', c);
}
render(){
const {isHot} = this.state
return(
<div>
<h2>今天天气很{isHot ? '炎热' : '冰爽'}</h2>
{/* jsx注释如下 */}
{/*<input ref={(c)=>{this.input1=c;console.log('@',c);}} type="text"></input><br/>*/}
<input ref={this.saveInput} type="text"></input><br />
<button onClick={this.showInfo}>点我提示输入的数据</button>
<button onClick={this.changeWeather}>点我切换天气</button>
</div>
)
}
}
//2.渲染组件到页面
ReactDOM.render(<Demo/>,document.getElementById("test"));
</script>
</body>
</html>
=================
类联掉调2次( <input ref={(c)=>{this.input1=c;console.log('@',c);}} type="text"></input><br/>);第一次传入参数 null
,然后第二次会传入参数 DOM 元素。这是因为在每次渲染时会创建一个新的函数实例,所以 React 清空旧的 ref 并且设置新的。
===
绑定函数不会
React之回调ref中回调执行次数的问题相关推荐
- reactjs组件实例三大属性之refs使用示例:字符串形式的ref、回调函数形式的ref、回调ref中回调执行次数的问题
1_字符串形式的ref <!DOCTYPE html> <html lang="en"> <head><meta charset=&quo ...
- 【Promise】入门-同步回调-异步回调-JS中的异常error处理-Promis的理解和使用-基本使用-链式调用-七个关键问题
文章目录 1. 预备知识 1.1 实例对象与函数对象 1.2 两种类型的回调函数 1. 同步回调 2. 异步回调 1.3 JS中的异常error处理 1. 错误的类型 2. 错误处理(捕获与抛出) 3 ...
- 【Android 高性能音频】AAudio 音频流 PCM 采样 的 采样 缓冲 播放 的 连续机制 ( 数据回调机制 | 数据回调函数指针 | 实现数据回调函数 | 设置数据回调函数 )
文章目录 I . AAudio 音频流 采样 缓冲 播放 的连续机制 II . AAudio 音频流 数据回调函数 函数指针类型定义 III . AAudio 音频流 数据回调函数 实现 IV . A ...
- spring返回数据使用ajax,【spring 后台跳转前台】使用ajax访问的后台,后台正常执行,返回数据,但是不能进入前台的ajax回调函数中...
问题1: 使用ajax访问的后台,后台正常执行,并且正常返回数据,但是不能进入前台的ajax回调函数中 问题展示: 问题解决: 最后发现是因为后台的方法并未加注解:@ResponseBody,导致方法 ...
- java 自定义函数的调用_Java/Android中的函数调用回调函数自定义回调函数
在做Android自定义控件时遇到要自定义回调函数的问题,想想自己还暂时没有那么精深的技术,赶紧返过头回来再重新研究Java中回调函数的问题.然而不幸的是,网上太多杂乱的帖子和博客都是转来转去,而且都 ...
- JavaScript 回调函数中的 return false 问题
今天一个同事问了我一个问题,就是在 Ajax 方法中,请求成功后(success)的回调函数中根据响应的值来判断程序是否继续执行,他不解的是在回调函数中已经 return false 了,但是 Aja ...
- Java代码块回调,QueueEvent - 队列化执行线程和代码块
QueueEvent 队列化执行线程和代码块 函数说明 1.主要有两个子类,QueueEventThread用来顺序执行线程,QueueEventCode用来顺序执行代码 2.可以使用setSpeed ...
- Python 3.X 调用多线程C模块,并在C模块中回调python函数的示例
由于最近在做一个C++面向Python的API封装项目,因此需要用到C扩展Python的相关知识.在此进行简要的总结. 此篇示例分为三部分.第一部分展示了如何用C在Windows中进行多线程编程:第二 ...
- html js 回调函数,js中回调函数的学习笔记
回调函数是什么在学习之前还真不知道js回调函数怎么使用及作用了,下面本文章把我在学习回调函数例子给各位同学介绍一下吧,有需了解的同学不防进入参考. 回调函数原理: 我现在出发,到了通知你" ...
最新文章
- POJ 1038 Bugs Integrated Inc (复杂的状压DP)
- 字符驱动之按键(一:无脑轮询法)
- 理解SetCapture、ReleaseCapture、GetCapture(控制了消息发往哪个窗口,是理解消息的关键)
- boost::fusion::pair用法的测试程序
- Django-RESTframework序列器
- AEAI DP开发统计分析
- 传智播客-刘意-java深入浅出精华版学习笔记Day03
- SmartUpload出现的问题
- android上下居中,android Spinner:在spinner中垂直居中文本
- win10计算机上的策略禁止用户安装,win10电脑安装摄像头驱动时提示策略禁止安装此设备的解决教程...
- 米哈游服务器一个月维护消费多少,崩坏3:为什么现在还有这么多米卫兵一直维护米哈游?这个理由说到心里去了...
- 代码解读一 文件名“ANO_Imu.c”
- 画出Android的大体架构图
- 学生专用计算机怎么没声音,win7麦克风没声音怎么设置_电脑麦克风没声音怎么办...
- 《在一起》评论分析1.0版
- 十大网址导航站排行榜
- S32K144(4)LED
- 小伙家乡搞养殖,从穷小子到资产上百万,带动了村民一起致富
- cubieboard上通过U-boot点亮板载LED
- Google SEO 教程-跨境知道
热门文章
- 技术干货 | mPaaS 框架下如何使用 Crash SDK 对闪退进行分析?
- 十年探索,云上明灯,re:Invent再启掀产业风暴
- Kubernetes 并非灵丹妙药...
- 国内厂商 Onyx 违反 GPL 协议,中国开源何去何从?
- 年薪15W的程序员因为掌握这个技能,薪资翻倍!
- Spark3.0发布了,代码拉过来,打个包,跑起来!| 附源码编译
- 【当头棒喝】你是真的了解云计算吗?
- 安全,从写第一行代码开始!
- 设置android应用闪屏图片_Android实现启动页面(闪屏页面)
- java 1m_Java编程测试1M内存可用来缓存多少对象