首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当设置图像标签角色时,按钮jsx-a11y显示警告

当设置图像标签角色时,按钮jsx-a11y显示警告
EN

Stack Overflow用户
提问于 2018-11-06 14:51:47
回答 2查看 3.9K关注 0票数 2

我需要使图像标签可点击,但我得到了一个警告由jsx-a11y,我如何修复它,我已经读取了no-noninteractive-element-interactions,但我不想包装其他div标签img标签,因为它会做一个冗余标签,所以有没有其他方法来修复这个警告?

警告是[eslint] Non-interactive elements should not be assigned interactive roles.

我的代码是

代码语言:javascript
复制
  <img
    styleName="pic-id-code"
    src={picCodeImgSrc}
    alt="pic id code"
    onClick={this.refreshPicCodeImg}
    onKeyPress={this.handleKeyPress}
    role="button"
    tabIndex="0"
  />
EN

回答 2

Stack Overflow用户

发布于 2018-11-23 20:01:03

你应该在你的用例中使用,它在语义上是正确的,你不需要添加roletabindex或任何其他ARIA标签来使它工作和可访问。

这里有一个警告,因为在点击之后,这实际上不会返回到正常状态,并且仍然是焦点,所以你需要在你的模糊逻辑之后调用onClick。这是我几天前制作的simple demo,用来消除点击时的焦点。

票数 1
EN

Stack Overflow用户

发布于 2018-11-06 15:12:56

您可以为指定行禁用eslint,如下所示

代码语言:javascript
复制
// eslint-disable-next-line THE-RULE-HERE
<img
    styleName="pic-id-code"
    src={picCodeImgSrc}
    alt="pic id code"
    onClick={this.refreshPicCodeImg}
    onKeyPress={this.handleKeyPress}
    role="button"
    tabIndex="0"
  />

不知道你的规则到底是什么,但试试这个

代码语言:javascript
复制
// eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions

代码语言:javascript
复制
// eslint-disable-next-line no-noninteractive-element-interactions

操作注释之后的更新

...但是在react jsx中没有工作

尝尝这个

代码语言:javascript
复制
<img
        styleName="pic-id-code"
        src={picCodeImgSrc}
        alt="pic id code"
        // eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
        onClick={this.refreshPicCodeImg}
        // eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
        onKeyPress={this.handleKeyPress}
        // eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
        role="button"
        tabIndex="0"
      />

img上的onClickoneKeyPress也会触发警告。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53166992

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档