React 方法 事件
2019-01-08 14:10
52 查看
React 方法
方法中不涉及this的,就按正常的写法;如果涉及,则改变this指向
下面列举3种方式
- 1 调用方法时bind(this)
getMsg(){ alert(this.state.msg) } <button onClick={this.getMsg.bind(this)}>按钮</button> // 不要this.getMsg() 不然每次页面刷新,不要点击,自己先触发
- 2 constructor bind(this)
constructor(props){ super(props) this.state={ msg:"sssss" } this.run = this.run.bind(this); } run(){ alert(this.state.msg) } <button onClick={this.run>按钮</button>
- 3 箭头函数,最常用的
run=()=> { alert(this.state.name) } <button onClick={this.run>按钮</button> // 箭头函数中没有this的概念
之前写React Native的时候有这种写法,亲测有效
getMsg(){ alert(this.state.msg) } <button onClick={()=>this.getMsg()}>按钮</button>
React 事件
事件对象
- 在触发DOM上的某个事件时,会产生一个事件event,这个对象中包含着所有与事件相关的信息。console.log(e) ,console.log(e.target)获取DOM
<button onClick={this.getMsg}>按钮</button>
获取DOM,修改属性
e.target.style.background="yellow"
插入小程序的操作DOM
<button cid="d1" onClick={this.getMsg}>按钮</button>
e.target.getAttribute("cid") //d1
表单事件
1.监听表单值改变 onChange
2.在onChange对应的方法中获取输入的值 e.targe.value
3.表单的值赋值 setState e.targe.value
除了事件对象,还有ref获取DOM
var name=this.refs.input.value <input type="text" ref="input"/>
键盘事件
onKeyUp e.keyCode
表单回车提交
if(e.keyCode==13){ // e.target.value }
如有问题,望斧正,也欢迎交流,共同脱坑
相关文章推荐
- React Native 原生与JS之间事件绑定注册 作用在于原生可以直接调用JS的方法
- React绑定事件动态化的实现方法
- react阻止冒泡事件(使用原生js方法)
- react.js 点击事件传递参数的方法
- React学习之事件绑定的几种方法对比
- React事件绑定几种方法测试
- React+Antd+Redux实现待办事件的方法
- React.Js添加与删除onScroll事件的方法详解
- 页面引入jtopo后,键盘方向键事件无用解决方法
- 浅析JavaScript事件和方法
- iOS开发中oc代码响应js网页点击事件的方法
- jQuery 事件 - one() 方法
- jquery利用命名空间移除绑定事件的方法
- jQuery 事件 - ready() 方法
- C# ToolStrip.ItemClicked 事件不能响应二级菜单(子菜单)的解决方法
- Win8怎么查看系统事件日志|Win8查看系统日志的方法
- Qt中事件处理的方法(图文并茂,仔细看看)
- 热插拔uevent事件用户空间截获方法和具体实现
- 学习笔记_android四种点击事件方法
- input text 的事件及方法