合成事件

此参考指南记录了构成 React 事件系统一部分的 SyntheticEvent 包装器。请参考有关事件处理的指南来了解更多。

概览

SyntheticEvent 实例将被传递给你的事件处理函数,它是浏览器的原生事件的跨浏览器包装器。除兼容所有浏览器外,它还拥有和浏览器原生事件相同的接口,包括 stopPropagation()preventDefault()

如果因为某些原因,当你需要使用浏览器的底层事件时,只需要使用 nativeEvent 属性来获取即可。合成事件与浏览器的原生事件不同,也不会直接映射到原生事件。例如,在 onMouseLeave 事件中 event.nativeEvent 将指向 mouseout 事件。每个 SyntheticEvent 对象都包含以下属性:

  1. boolean bubbles
  2. boolean cancelable
  3. DOMEventTarget currentTarget
  4. boolean defaultPrevented
  5. number eventPhase
  6. boolean isTrusted
  7. DOMEvent nativeEvent
  8. void preventDefault()
  9. boolean isDefaultPrevented()
  10. void stopPropagation()
  11. boolean isPropagationStopped()
  12. void persist()
  13. DOMEventTarget target
  14. number timeStamp
  15. string type

注意:

从 v17 开始,e.persist() 将不再生效,因为 SyntheticEvent 不再放入事件池中。

注意:

从 v0.14 开始,事件处理器返回 false 时,不再阻止事件传递。你可以酌情手动调用 e.stopPropagation()e.preventDefault() 作为替代方案。

支持的事件

React 通过将事件 normalize 以让他们在不同浏览器中拥有一致的属性。

以下的事件处理函数在冒泡阶段被触发。如需注册捕获阶段的事件处理函数,则应为事件名添加 Capture。例如,处理捕获阶段的点击事件请使用 onClickCapture,而不是 onClick


参考

剪贴板事件

事件名:

  1. onCopy onCut onPaste

属性:

  1. DOMDataTransfer clipboardData

复合事件

事件名:

  1. onCompositionEnd onCompositionStart onCompositionUpdate

属性:

  1. string data

键盘事件

事件名:

  1. onKeyDown onKeyPress onKeyUp

属性:

  1. boolean altKey
  2. number charCode
  3. boolean ctrlKey
  4. boolean getModifierState(key)
  5. string key
  6. number keyCode
  7. string locale
  8. number location
  9. boolean metaKey
  10. boolean repeat
  11. boolean shiftKey
  12. number which

key 属性可以是 DOM Level 3 Events spec 里记录的任意值。


焦点事件

事件名:

  1. onFocus onBlur

这些焦点事件在 React DOM 上的所有元素都有效,不只是表单元素。

属性:

  1. DOMEventTarget relatedTarget

onFocus

onFocus 事件在元素(或其内部某些元素)聚焦时被调用。例如,当用户点击文本输入框时,就会调用该事件。

  1. function Example() {
  2. return (
  3. <input
  4. onFocus={(e) => {
  5. console.log('Focused on input');
  6. }}
  7. placeholder="onFocus is triggered when you click this input."
  8. />
  9. )
  10. }

onBlur

onBlur 事件处理程序在元素(或元素内某些元素)失去焦点时被调用。例如,当用户在已聚焦的文本输入框外点击时,就会被调用。

  1. function Example() {
  2. return (
  3. <input
  4. onBlur={(e) => {
  5. console.log('Triggered because this input lost focus');
  6. }}
  7. placeholder="onBlur is triggered when you click this input and then you click outside of it."
  8. />
  9. )
  10. }

监听焦点的进入与离开

你可以使用 currentTargetrelatedTarget 来区分聚焦和失去焦点是否来自父元素外部。这里有个 DEMO,你可以复制并在本地运行,它展示了如何监听一个子元素的聚焦,元素本身的聚焦,以及整个子树进入焦点或离开焦点。

  1. function Example() {
  2. return (
  3. <div
  4. tabIndex={1}
  5. onFocus={(e) => {
  6. if (e.currentTarget === e.target) {
  7. console.log('focused self');
  8. } else {
  9. console.log('focused child', e.target);
  10. }
  11. if (!e.currentTarget.contains(e.relatedTarget)) {
  12. // Not triggered when swapping focus between children
  13. console.log('focus entered self');
  14. }
  15. }}
  16. onBlur={(e) => {
  17. if (e.currentTarget === e.target) {
  18. console.log('unfocused self');
  19. } else {
  20. console.log('unfocused child', e.target);
  21. }
  22. if (!e.currentTarget.contains(e.relatedTarget)) {
  23. // Not triggered when swapping focus between children
  24. console.log('focus left self');
  25. }
  26. }}
  27. >
  28. <input id="1" />
  29. <input id="2" />
  30. </div>
  31. );
  32. }

表单事件

事件名:

  1. onChange onInput onInvalid onReset onSubmit

想了解 onChange 事件的更多信息,查看 Forms


通用事件

事件名:

  1. onError onLoad

鼠标事件

事件名:

  1. onClick onContextMenu onDoubleClick onDrag onDragEnd onDragEnter onDragExit
  2. onDragLeave onDragOver onDragStart onDrop onMouseDown onMouseEnter onMouseLeave
  3. onMouseMove onMouseOut onMouseOver onMouseUp

onMouseEnteronMouseLeave 事件从离开的元素向进入的元素传播,不是正常的冒泡,也没有捕获阶段。

属性:

  1. boolean altKey
  2. number button
  3. number buttons
  4. number clientX
  5. number clientY
  6. boolean ctrlKey
  7. boolean getModifierState(key)
  8. boolean metaKey
  9. number pageX
  10. number pageY
  11. DOMEventTarget relatedTarget
  12. number screenX
  13. number screenY
  14. boolean shiftKey

指针事件

事件名:

  1. onPointerDown onPointerMove onPointerUp onPointerCancel onGotPointerCapture
  2. onLostPointerCapture onPointerEnter onPointerLeave onPointerOver onPointerOut

onPointerEnteronPointerLeave 事件从离开的元素向进入的元素传播,不是正常的冒泡,也没有捕获阶段。

属性:

W3 spec 中定义的,指针事件通过以下属性扩展了鼠标事件

  1. number pointerId
  2. number width
  3. number height
  4. number pressure
  5. number tangentialPressure
  6. number tiltX
  7. number tiltY
  8. number twist
  9. string pointerType
  10. boolean isPrimary

关于跨浏览器支持的说明:

并非每个浏览器都支持指针事件(在写这篇文章时,已支持的浏览器有:Chrome,Firefox,Edge 和 Internet Explorer)。React 故意不通过 polyfill 的方式适配其他浏览器,主要是符合标准的 polyfill 会显著增加 react-dom 的 bundle 大小。

如果你的应用要求指针事件,我们推荐添加第三方的指针事件 polyfill。


选择事件

事件名:

  1. onSelect

触摸事件

事件名:

  1. onTouchCancel onTouchEnd onTouchMove onTouchStart

属性:

  1. boolean altKey
  2. DOMTouchList changedTouches
  3. boolean ctrlKey
  4. boolean getModifierState(key)
  5. boolean metaKey
  6. boolean shiftKey
  7. DOMTouchList targetTouches
  8. DOMTouchList touches

UI 事件

事件名:

  1. onScroll

注意

从 React 17 开始,onScroll 事件在 React 中不再冒泡。这与浏览器的行为一致,并且避免了当一个嵌套且可滚动的元素在其父元素触发事件时造成混乱。

属性:

  1. number detail
  2. DOMAbstractView view

滚轮事件

事件名:

  1. onWheel

属性:

  1. number deltaMode
  2. number deltaX
  3. number deltaY
  4. number deltaZ

媒体事件

事件名:

  1. onAbort onCanPlay onCanPlayThrough onDurationChange onEmptied onEncrypted
  2. onEnded onError onLoadedData onLoadedMetadata onLoadStart onPause onPlay
  3. onPlaying onProgress onRateChange onSeeked onSeeking onStalled onSuspend
  4. onTimeUpdate onVolumeChange onWaiting

图像事件

事件名:

  1. onLoad onError

动画事件

事件名:

  1. onAnimationStart onAnimationEnd onAnimationIteration

属性:

  1. string animationName
  2. string pseudoElement
  3. float elapsedTime

过渡事件

事件名:

  1. onTransitionEnd

属性:

  1. string propertyName
  2. string pseudoElement
  3. float elapsedTime

其他事件

事件名:

  1. onToggle