React 之事件
一、编写事件处理函数
- 在函数体中进行一些操作,常见的有:更新页面内容,更新组件状态,与后台交互
书写方式
var Demo = React.createClass({
getInitialState:function(){},
handleClick: function(event){},
handleChange: function(){},
render:function(){},
})
- 上面的代码中有的有参数
event
,有的没有,这个根据自己的需求
二、绑定事件处理函数
onClick={this,handleClick}
- 需要注意的是:不要在事件后面添加上一个
()
其他的事件
- 触摸事件:
onTouchCancel
,onTouchEnd
,onTouchMove
,onTouchStart
- 键盘事件:
onKeyDown
,onKeyUp
,onKeyPress
(前两者的组合) - 表单时间:
onChange
,onInput
,onSubmit
- 焦点事件:
onFocus
,onBlur
- UI 元素事件:
onScroll
- 滚动事件:
onWhell
(鼠标滚动) - 鼠标事件:
onClick
,onContextMenu
,onDoubleClick
……
var Demo = React.createClass({
handleClick:function(e){
console.log(e)
console.log(e.target)
console.log(e.nativeEvent)
},
render:function(){
return <div onClick={this.handleClick}>Hello World</div>
}
})
ReactDOM.render(<Demo/>,document.getElementById('app'))
var Demo = React.createClass({
getInitialState:function(){
return {
width: 200,
height: 200,
backgroundColor: '#DDDDDD'
}
},
/*handleWheel:function(e){
var newColor = (parseInt(this.state.backgroundColor.substr(1),16) + e.deltaY).toString(16)
newColor = '#' + newColor.toUpperCase()
console.log(newColor)
this.setState({
backgroundColor:newColor
})
},*/
randomColor:function(){
var r = Math.floor(Math.random()*256);
var g = Math.floor(Math.random()*256);
var b = Math.floor(Math.random()*256);
return 'rgb('+r+','+g+','+b+')'
},
handleWheel:function(){
this.setState({
backgroundColor:this.randomColor()
})
},
render:function(){
return <div onWheel={this.handleWheel} style={this.state}>这是一个案例,鼠标滚动实现背景颜色的变化</div>
}
})
ReactDOM.render(<Demo/>,document.getElementById('app'))
三、事件对象
事件对象的使用
- 通用:所有的事件都有事件属性
- 键盘:键盘事件拥有的事件属性
- 鼠标:鼠标事件拥有的事件属性
- 滚动:滚动事件拥有的事件属性
- 为什么会有三个,因为有的设备可以实现三个方向的移动
四、事件与状态关联
inputChange:function(event){
this.setState({
inputText:event.target.value
})
}
- 总的来说就是使用
this.setState
来更新状态,而状态的值因为事件的不同会不同
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: React 之组件的协同及(不)可控组件
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论