- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用快捷链接来加快浏览网页的速度,这在 Chrome 和 Firefox 中运行良好。
这是 Fiddle demonstrating my issue .
当使用跳过链接更改“选项卡位置”时,然后按 TAB
关键是,大多数浏览器从那时起继续按顺序跳到可聚焦的交互式或使用 tabindex 的元素上:
<div class="skiplinks">
<a href="#nav">Skip to Navigation</a>
<a href="#search">Skip to Search</a>
<a href="#anchor">Skip to anchor</a>
</div>
<div id="wrapper">
<p>Some boring content containing <a href="#">a selectable link</a>.</p>
<ul id="nav">
<li><a href="#">link 1</li>
<li><a href="#">link 2</li>
<li><a id="anchor">anchor with no href</li>
</ul>
<form id="search">
<input type="search" id="search-field" />
</form>
</div>
在此示例中,单击链接时,“制表符位置”将移动到文档中的该位置。紧迫TAB
然后将跳转到跳过链接的目标 之后 的下一个可聚焦元素 - try this demo .
除非您使用的是 IE。 IE 似乎只尊重“Tab 位置”的变化,前提是它们涉及关注交互式 元素或带有 tabindex
的元素。属性定义。这意味着 anchor 标记被用作“片段”或位置 anchor ,也不会导致 tabindex 被更新。
在上面的示例中,选择“跳过”链接然后点击 TAB
简单地跳回到页面上的第一个链接。选择“跳到 anchor ”然后选择“Tab”也会跳回顶部。这个怪癖似乎会影响 IE 8-11。
好的,那么为什么不直接将跳过链接指向交互式元素而不是包装器呢?我试过了,正好解决了IE中的bug,并在Firefox中引入了它。如果我优先考虑 IE 而不是 FF,我会被诅咒。
我是不是漏掉了一些非常明显的东西?
更新
我已经解决了这个问题,解决方案是只创建指向 <a>
的片段/跳过链接带有负数 tabindex
的标签赋值:
<a href="#destination">Skip to somewhere down the page</a>
<a id="destination" tabindex="-1"></a>
适用于 Chrome、FF 和 IE。
最佳答案
正如我在评论中提到的,div
不是制表位(它可以有焦点,但它不是制表位)。对于 Internet Explorer,以下元素是可聚焦的,但不代表制表位:applet
, div
, frameset
, span
, table
和 td
(来源MSDN)。在现代浏览器中,但在旧浏览器中,您可以使用任何具有已定义 id
的元素。作为 anchor - 也是一个制表位 - 但不适用于 Internet Explorer 11。代表 Internet Explorer 的制表位的唯一元素是:a
, body
, button
, frame
, iframe
, img
, input
, isIndex
(已弃用的元素),object
, select
和 textArea
.因此,跳转到制表位的最佳解决方案是使用这些元素之一或更明显的元素,即 anchor 链接。 anchor 链接是 a
带有 id
的元素没有 href
: <a id="tabstop"></a>
.问题或错误是,对于 Internet Explorer 11,没有 href 的 anchor 链接(它只需要定义,它可以是空的)不会像制表符一样工作。所以最好的解决方案是使用不带空(或 #
)href
的 anchor 链接.
在下面的片段中,“跳到 DIV”链接将跳转到第一个 div
, 所以在 Internet Explorer 11 上它不会代表制表位;使用选项卡将循环浏览页面中的所有链接。 “skip to ANCHOR”链接将跳转到一个 anchor 链接,在修复错误后, anchor 链接将代表一个制表位,因此按下 tab 将使光标跳转到下一个可制表元素:输入。
<div class="skiplinks">
<a href="#wrapper">Skip to DIV</a>
<a href="#anchor">Skip to ANCHOR</a>
</div>
<div id="wrapper">
<p>Some boring content containing a selectable <a href="#">link</a>.</p>
<ul id="nav">
<li><a href="#">link 1</a></li>
<li><a href="#">link 2</a></li>
<li><a id="anchor" href="">anchor with href</a></li>
</ul>
<form id="search">
<input type="search" id="search-field" />
</form>
</div>
希望对您有所帮助。
关于html - 为什么 IE 在浏览网页时忽略 'tab position',除非使用 'tabindex'?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49292986/
我刚开始使用 html5 和 css,我对使用 css position 有点困惑。 我可以从堆栈溢出中找到这些链接, Difference between relative and absolute
我想知道是否有一种方法可以获得相对定位的元素的“绝对位置”。我想不出任何方法,但也许有人想出了一个方法...... 最佳答案 我不确定“绝对位置”是什么意思,但您可以使用 el.getBounding
基本上我的 HTML(使用 Bootstrap 类)中有一个页面,其中包含使用 thumbnail 和 caption 类展示的产品。在产品图片上方有一个 ON SELL(圆形红色标签)。我给这个红色
当我使用 BaseAdapter 的 ListView 离开屏幕时,每一行不再保持连续的位置。除了这个我不知道还能怎么解释。 如果我的 BA/LV 在屏幕上显示 4 个项目,并且我添加了一个显示每一行
此 HTML 无法在 IE8 中正确呈现。它适用于 Firefox、Opera、IE7、IE9 和 IE10。 (当然,它在 IE6 中也不起作用,因为它涉及固定位置的元素。) 实际上它在 Chrom
我正在使用Position Absolute的表单验证引擎。 我有一个特定的验证案例,希望可以为我解决。我需要能够根据另一个字段的值来使一个字段成为必需。 例如: If country.dropdow
我看过很多帖子,人们希望将相机位置调整到屏幕位置。我的问题是如何做相反的事情。 我目前想要实现的是将“门”位置设置为屏幕的百分比,此计算已准备就绪,并且我确实有最终屏幕的 X、Y (px) 位置。相机
谁能解释一下使用 position:relative、position:absolute 和 float 对正常文档流及其子项的影响的区别? 例如当我有三个元素 A、B、C 时,其中 A 是包含 B
我有以下代码: .tabs{ position: fixed; top:110px; left:0px; width:40px; z-inde
我不知道如何表达这个问题。 所以这是一个例子。 图层上的动画滑入 View ,然后稍微弹回。 十分简单。 位置关键帧看起来像这样: 关键帧 0:(-100,200) 关键帧 10:(100,200)
我是 XSLT 的新手,我正在使用 w3schools 的“自己尝试”页面进行一些测试。我正在使用以下演示: http://www.w3schools.com/xsl/tryxslt.asp?xmlf
我试图让一个对象 1 (SKSpriteNode) 在某个高度(y 坐标)处创建另一个对象 (object2)。我已经得到了我需要的所有代码,除了我不知道如何正确编写: object1.positio
.special p { display:none; } .special:hover p { display:block; } Things
当将一个绝对定位元素放置在一个位置固定包装器中时,在一个位置相对包装器中,绝对元素位置不应该相对于相对 parent 而不是固定 parent ? Content
我有一个 iframe,它在应用 css 后显示谷歌地图 position: relative; top: 48px; left: -233px; 但是当我向下滚动时,它刚好出现在显示 khaleej
我在一个网站上工作,有一个带有 position:relative 的父元素,它有一个带有 position:absolute 的子元素。令我感到奇怪的是,对于我提到的位置,子元素似乎仍然可以识别它们
我有一个 main 元素,我已将其设置为 position: relative。这包含两个 div,然后我在其上应用 position: absolute。然后,这会导致夹在 main 元素中间的页眉
HTML 代码由一个 div 组成,它具有两种类型的类:“隐藏”和“保留”。 Lorem ipsum dolor sit amet, consectetur adipis
我必须开发一个生成表格(有点……)的软件,并且必须提供对元素位置的完全控制。 到目前为止,我们有这样的构造: 还有一些javascript代码来放置#a , #b和 #c #co
我尝试将 z-index 设置为 body 下的某些位置为 fixed 的元素 示例如下: HTML menu content ....
我是一名优秀的程序员,十分优秀!