ユーザーが選択できるドロップダウンオプションのリストがあります。
ドロップダウンのオプティノは次のタグで作成されています:<a href>:
<a onClick={() => handleSelect(filter)} role="button">
{filter.name}
</a>
Eslintからのエラーを修正するためにtabIndex="0" or -1
を追加する必要があります。
しかし、tabIndex=0
を追加すると、ボタンが機能しなくなります。
このエラーを修正する他の方法はありますか?
これは、ドロップダウンコンポーネントの外観です。
<ul name="filters" className="dropdown">
{filterOptions.map((filter) => (
<li
key={filter.id}
defaultChecked={filter.name}
name={filter.name}
className={`option option-${filter.selected ? 'selected' : 'unselected'}`}
>
<span className={`option-${filter.selected ? 'checked-box' : 'unchecked-box'} `} />
<a onClick={() => handleSelect(filter)} role="button">
{filter.name}
</a>
</li>
))}
</ul>
ボタンはインタラクティブなコントロールであるため、フォーカス可能です。ボタンの役割がそれ自体ではフォーカスできない要素(
<span>
、<div>
、<p>
など)に追加されている場合、ボタンをフォーカス可能にするためにtabindex属性を使用する必要があります。 。
HTML属性
tabindex
は、Reactの属性tabIndex
に対応しています。
https://reactjs.org/docs/dom-elements.html
@S ..答えは正しいと思います:
<a
onClick={() => handleSelect(filter)}
role="button"
tabIndex={0}
>
{filter.name}
</a>
Tabindexを追加します。
<a onClick={() => handleSelect(filter)} role="button" tabIndex={i}>
{filter.name}
</a>
最初にイテレータをマップに追加した後:(filter, i)
<a
dataTest="create-event-link"
className="c-link c-link--text"
onClick={() => setCreateEvent(!createEvent)}
role="button"
>