web 3d图形渲染器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

137 lines
5.4 KiB

  1. # no-noninteractive-element-interactions
  2. Non-interactive HTML elements and non-interactive ARIA roles indicate _content_ and _containers_ in the user interface. A non-interactive element does not support event handlers (mouse and key handlers). Non-interactive elements include `<main>`, `<area>`, `<h1>` (,`<h2>`, etc), `<p>`, `<img>`, `<li>`, `<ul>` and `<ol>`. Non-interactive [WAI-ARIA roles](https://www.w3.org/TR/wai-aria-1.1/#usage_intro) include `article`, `banner`, `complementary`, `img`, `listitem`, `main`, `region` and `tooltip`.
  3. ## How do I resolve this error?
  4. ### Case: This element acts like a button, link, menuitem, etc.
  5. Move the event handler function to an inner element that is either a semantically interactive element (`<button>`, `<a href>`) or that has an interactive role. This leaves the _content_ or _container_ semantic value of this element intact.
  6. Common interactive roles include:
  7. 1. `button`
  8. 1. `link`
  9. 1. `checkbox`
  10. 1. `menuitem`
  11. 1. `menuitemcheckbox`
  12. 1. `menuitemradio`
  13. 1. `option`
  14. 1. `radio`
  15. 1. `searchbox`
  16. 1. `switch`
  17. 1. `textbox`
  18. Note: Adding a role to your element does **not** add behavior. When a semantic HTML element like `<button>` is used, then it will also respond to Enter key presses when it has focus. The developer is responsible for providing the expected behavior of an element that the role suggests it would have: focusability and key press support.
  19. see [WAI-ARIA Authoring Practices Guide - Design Patterns and Widgets](https://www.w3.org/TR/wai-aria-practices-1.1/#aria_ex).
  20. ### Case: This element is catching bubbled events from elements that it contains
  21. Move the event handler function to an inner element like `<div>` and give that element a role of `presentation`. This leaves the _content_ or _container_ semantic value of this element intact.
  22. ```jsx
  23. <div role="article">
  24. <div
  25. onClick="onClickHandler"
  26. onKeyPress={onKeyPressHandler}
  27. role="presentation">
  28. {this.props.children}
  29. </div>
  30. </div>
  31. ```
  32. Marking an element with the role `presentation` indicates to assistive technology that this element should be ignored; it exists to support the web application and is not meant for humans to interact with directly.
  33. ### Case: This is a heading that expands/collapses content on the package
  34. Headers often double as expand/collapse controls for the content they headline. An accordion component is a common example of this pattern. Rather than assign the interaction handling code to the heading itself, put a button inside the heading instead. This pattern retains the role of the heading and the role of the button.
  35. ```jsx
  36. <h3>
  37. <button onClick={this._expandSection}>News</button>
  38. </h3>
  39. <ul id="articles-list">
  40. <li>...</li>
  41. </ul>
  42. ```
  43. ### Case: This element is a table cell
  44. Table cells (and tables in general) are meant to contain data. ARIA provides us with a construct called a [Grid](http://w3c.github.io/aria-practices/#grid) that is essentially a 2 dimensional logical container for content and interactive elements.
  45. You have two options in this case.
  46. #### Option 1, move the interactive content inside the table cells
  47. For instance, move the button inside the cell:
  48. ```jsx
  49. <table>
  50. <tr>
  51. <td><button>Sort</button></td>
  52. </tr>
  53. </table>
  54. ```
  55. This preserves the table cell semantics and the button semantics; the two are not conflated on the cell.
  56. #### Option 2, convert the table into an ARIA grid
  57. If your user interface has a table-like layout, but is filled with interactive components in the cells, consider converting the table into a grid.
  58. ```jsx
  59. <table role="grid">
  60. <tr>
  61. <td role="gridcell" onClick={this.sort}>Sort</td>
  62. </tr>
  63. </table>
  64. ```
  65. You can also put the interactive content inside the grid cell. This maintains the semantic distinction between the cell and the interaction content, although a grid cell can be interactive.
  66. ## Rule details
  67. You may configure which handler props should be taken into account when applying this rule. The recommended configuration includes the following 6 handlers.
  68. ```javascript
  69. 'jsx-a11y/no-noninteractive-element-interactions': [
  70. 'error',
  71. {
  72. handlers: [
  73. 'onClick',
  74. 'onMouseDown',
  75. 'onMouseUp',
  76. 'onKeyPress',
  77. 'onKeyDown',
  78. 'onKeyUp',
  79. ],
  80. },
  81. ],
  82. ```
  83. Adjust the list of handler prop names in the handlers array to increase or decrease the coverage surface of this rule in your codebase.
  84. ### Succeed
  85. ```jsx
  86. <div onClick={() => void 0} role="button" />
  87. <div onClick={() => void 0} role="presentation" />
  88. <input type="text" onClick={() => void 0} /> // Interactive element does not require role.
  89. <button onClick={() => void 0} className="foo" /> // button is interactive.
  90. <div onClick={() => void 0} role="button" aria-hidden /> // This is hidden from screenreader.
  91. <Input onClick={() => void 0} type="hidden" /> // This is a higher-level DOM component
  92. ```
  93. ### Fail
  94. ```jsx
  95. <li onClick={() => void 0} />
  96. <div onClick={() => void 0} role="listitem" />
  97. ```
  98. ## Accessibility guidelines
  99. - [WCAG 4.1.2](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)
  100. ### Resources
  101. - [WAI-ARIA roles](https://www.w3.org/TR/wai-aria-1.1/#usage_intro)
  102. - [WAI-ARIA Authoring Practices Guide - Design Patterns and Widgets](https://www.w3.org/TR/wai-aria-practices-1.1/#aria_ex)
  103. - [Fundamental Keyboard Navigation Conventions](https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_generalnav)
  104. - [Mozilla Developer Network - ARIA Techniques](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_button_role#Keyboard_and_focus)