gpt4 book ai didi

javascript - Tabindex 在 Chrome 中不工作(React 应用程序)

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:30:33 27 4
gpt4 key购买 nike

我使用 react 和 react-modal 在网站上创建叠加层。该叠加层包含各种元素以及一个表单(下面的概述)。我希望能够使用 TAB 键引导用户浏览表单。我将 tabindex=0 分配给按出现顺序可切换的所需元素。

我的问题是:它在 Chrome(版本 61.0.3163.100)中不起作用,但在 Firefox 中却可以。我读到,如果 DOM 树上的任何元素不可见或高度/宽度为 0,就会发生这种情况。我进行了一些样式更改以修复该问题,但没有效果。

<div class="ReactModalPortal">
<div data-reactroot="" class="ReactModal__Overlay" style="position: fixed; top: 0px; left: 0px; right: 0px; bottom: 0px;">
<div class="ReactModal__Content" tabindex="-1" aria-label="Questionnaire" style="position: absolute; top: 0px; left: 0px; right: 0px; height: 100%; background: transparent none repeat scroll 0% 0%; overflow: auto;">
<!-- Some other stuff and nested elements -->
<div id="...">
<form>
<input tabindex="0">
<button tabindex="0">
</form>
</div>
</div>
</div>

如您所见,其中一个父元素具有 tabindex="-1"。当通过 Chrome 中的检查功能或以编程方式使用 JS 更改它时,问题仍然存在(或者如果元素最初是使用此索引呈现的,是否有所不同?)。

更新

我意识到是其他原因导致了问题。我在模式的根节点上使用 CSS 属性 initial: all 将我的内部 CSS 与外部的所有内容隔离开来。由于某种原因,这阻止了 tabindex 工作。如果你能帮助我理解,我会奖励这个赏金。我的解决方法就是不使用 all: initial(它无论如何都不兼容 IE,而且我知道没有真正好的替代方案)。

最佳答案

all: initial 使用初始属性重置节点的所有 CSS 属性。

对于 display 属性,初始值为 inline

因此,将 all: initial 设置为根 div 会将 display 属性设置为内联。 inline 元素没有高度或宽度,因此它们是 0x0。

这也是因为 div 只包含固定的、绝对定位的元素。

React Modal 通过对模态内的所有元素运行一个循环来检查元素是否可聚焦。但是,对于可聚焦的元素,它必须是可见的。对于每个元素,我们必须迭代直到 body 元素以确保它的可见性。

这是检查元素是否可见的函数。

function hidden(el) {
return (
(el.offsetWidth <= 0 && el.offsetHeight <= 0) || el.style.display === "none"
);
}

如您所见,我们的 div 将没有 offsetHeightoffsetWidth 并且将被视为隐藏。因此,模态不能不被聚焦。

关于javascript - Tabindex 在 Chrome 中不工作(React 应用程序),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46907790/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com