--- 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() boolean isDefaultPrevented() void stopPropagation() boolean isPropagationStopped() DOMEventTarget target number timeStamp string type ``` > 注意: > > React v0.14 中,事件处理程序返回 `false` 不再停止事件传播,取而代之,应该根据需要手动触发 `e.stopPropagation()` 或 `e.preventDefault()`。 ## 事件池 `SyntheticEvent` 是池化的. 这意味着 `SyntheticEvent` 对象将会被重用并且所有的属性都会在事件回调被调用后被 nullified. 这是因为性能的原因. 因此,你不能异步的访问事件. ```javascript function onClick(event) { console.log(event); // => nullified object. console.log(event.type); // => "click" var eventType = event.type; // => "click" setTimeout(function() { console.log(event.type); // => null console.log(eventType); // => "click" }, 0); this.setState({clickEvent: event}); // Won't work. this.state.clickEvent will only contain null values. this.setState({eventType: event.type}); // You can still export event properties. } ``` > 注意: > > 如果你想异步访问事件属性,你应该在事件上调用 `event.persist()` ,这会从池中移除合成事件并允许对事件的引用被用会保留. ## 支持的事件 React 将事件统一化,使事件在不同浏览器上有一致的属性. 下面的事件处理程序在事件冒泡阶段被触发。如果要注册事件捕获处理程序,应该使用 `Capture` 事件,例如使用 `onClickCapture` 处理点击事件的捕获阶段,而不是 `onClick`。 ### 剪贴板事件 事件名称: ``` onCopy onCut onPaste ``` 属性: ```javascript DOMDataTransfer clipboardData ``` ### Composition 事件 事件名称: ``` onCompositionEnd onCompositionStart onCompositionUpdate ``` 属性: ```javascript string data ``` ### 键盘事件 事件名称: ``` onKeyDown onKeyPress onKeyUp ``` 属性: ```javascript boolean altKey number charCode boolean ctrlKey boolean getModifierState(key) string key number keyCode string locale number location boolean metaKey boolean repeat boolean shiftKey number which ``` ### 焦点事件 事件名称 ``` onFocus onBlur ``` 属性: ```javascript DOMEventTarget relatedTarget ``` 焦点事件在所有的React DOM上工作,不仅仅是表单元素. ### 表单事件 事件名称: ``` 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 ``` `onMouseEnter` 和 `onMouseLeave` 事件从离开的元素传播到进入的元素,代替冒泡排序并且没有捕获阶段. 属性: ```javascript boolean altKey number button number buttons number clientX number clientY boolean ctrlKey boolean getModifierState(key) boolean metaKey number pageX number pageY DOMEventTarget relatedTarget number screenX number screenY boolean shiftKey ``` ### Selection Events 事件名称: ``` onSelect ``` ### 触控事件 事件名称: ``` onTouchCancel onTouchEnd onTouchMove onTouchStart ``` 属性: ```javascript boolean altKey DOMTouchList changedTouches boolean ctrlKey boolean 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 ``` ### Media Events 事件名称: ``` onAbort onCanPlay onCanPlayThrough onDurationChange onEmptied onEncrypted onEnded onError onLoadedData onLoadedMetadata onLoadStart onPause onPlay onPlaying onProgress onRateChange onSeeked onSeeking onStalled onSuspend onTimeUpdate onVolumeChange onWaiting ``` ### Image Events 事件名称: ``` onLoad onError ```