|
|
|
---
|
|
|
|
id: events-zh-CN
|
|
|
|
title: 事件系统
|
|
|
|
permalink: events-zh-CN.html
|
|
|
|
prev: tags-and-attributes-zh-CN.html
|
|
|
|
next: dom-differences-zh-CN.html
|
|
|
|
---
|
|
|
|
|
|
|
|
## 合成事件
|
|
|
|
|
|
|
|
事件处理程序通过 `合成事件`(`SyntheticEvent`)的实例传递,`SyntheticEvent` 是浏览器原生事件跨浏览器的封装。`SyntheticEvent` 和浏览器原生事件一样有 `stopPropagation()`、`preventDefault()` 接口,而且这些接口夸浏览器兼容。
|
|
|
|
|
|
|
|
如果出于某些原因想使用浏览器原生事件,可以使用 `nativeEvent` 属性获取。每个和成事件(`SyntheticEvent`)对象都有以下属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
boolean bubbles
|
|
|
|
boolean cancelable
|
|
|
|
DOMEventTarget currentTarget
|
|
|
|
boolean defaultPrevented
|
|
|
|
Number eventPhase
|
|
|
|
boolean isTrusted
|
|
|
|
DOMEvent nativeEvent
|
|
|
|
void preventDefault()
|
|
|
|
void stopPropagation()
|
|
|
|
DOMEventTarget target
|
|
|
|
Date timeStamp
|
|
|
|
String type
|
|
|
|
```
|
|
|
|
|
|
|
|
> 注意:
|
|
|
|
>
|
|
|
|
> React v0.12 中,事件处理程序返回 `false` 不再停止事件传播,取而代之,应该根据需要手动触发 `e.stopPropagation()` 或 `e.preventDefault()`。
|
|
|
|
|
|
|
|
|
|
|
|
## 支持的事件
|
|
|
|
|
|
|
|
React 将事件统一化,使事件在不同浏览器上有一致的属性。
|
|
|
|
|
|
|
|
下面的事件处理程序在事件冒泡阶段被触发。如果要注册事件捕获处理程序,应该使用 `Capture` 事件,例如使用 `onClickCapture` 处理点击事件的捕获阶段,而不是 `onClick`。
|
|
|
|
|
|
|
|
|
|
|
|
### 剪贴板事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onCopy onCut onPaste
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
DOMDataTransfer clipboardData
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 键盘事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onKeyDown onKeyPress onKeyUp
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
boolean altKey
|
|
|
|
Number charCode
|
|
|
|
boolean ctrlKey
|
|
|
|
function getModifierState(key)
|
|
|
|
String key
|
|
|
|
Number keyCode
|
|
|
|
String locale
|
|
|
|
Number location
|
|
|
|
boolean metaKey
|
|
|
|
boolean repeat
|
|
|
|
boolean shiftKey
|
|
|
|
Number which
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 焦点事件
|
|
|
|
|
|
|
|
事件名称
|
|
|
|
|
|
|
|
```
|
|
|
|
onFocus onBlur
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
DOMEventTarget relatedTarget
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 表单事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onChange onInput onSubmit
|
|
|
|
```
|
|
|
|
|
|
|
|
关于 `onChange` 事件的更多信息,参见 [表单组件](/react/docs/forms-zh-CN.html)。
|
|
|
|
|
|
|
|
|
|
|
|
### 鼠标事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onClick onContextMenu onDoubleClick onDrag onDragEnd onDragEnter onDragExit
|
|
|
|
onDragLeave onDragOver onDragStart onDrop onMouseDown onMouseEnter onMouseLeave
|
|
|
|
onMouseMove onMouseOut onMouseOver onMouseUp
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
boolean altKey
|
|
|
|
Number button
|
|
|
|
Number buttons
|
|
|
|
Number clientX
|
|
|
|
Number clientY
|
|
|
|
boolean ctrlKey
|
|
|
|
function getModifierState(key)
|
|
|
|
boolean metaKey
|
|
|
|
Number pageX
|
|
|
|
Number pageY
|
|
|
|
DOMEventTarget relatedTarget
|
|
|
|
Number screenX
|
|
|
|
Number screenY
|
|
|
|
boolean shiftKey
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 触控事件
|
|
|
|
|
|
|
|
在渲染任意组件之前调用 `React.initializeTouchEvents(true)`,以启用触控事件。
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onTouchCancel onTouchEnd onTouchMove onTouchStart
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
boolean altKey
|
|
|
|
DOMTouchList changedTouches
|
|
|
|
boolean ctrlKey
|
|
|
|
function getModifierState(key)
|
|
|
|
boolean metaKey
|
|
|
|
boolean shiftKey
|
|
|
|
DOMTouchList targetTouches
|
|
|
|
DOMTouchList touches
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 用户界面事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onScroll
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
Number detail
|
|
|
|
DOMAbstractView view
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### 滚轮事件
|
|
|
|
|
|
|
|
事件名称:
|
|
|
|
|
|
|
|
```
|
|
|
|
onWheel
|
|
|
|
```
|
|
|
|
|
|
|
|
属性:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
Number deltaMode
|
|
|
|
Number deltaX
|
|
|
|
Number deltaY
|
|
|
|
Number deltaZ
|
|
|
|
```
|