我可以让Firefox不显示丑陋的点状焦点轮廓的链接:
a:focus {
outline: none;
}
但我怎么能这样做<按钮>标签以及?当我这样做的时候:
button:focus {
outline: none;
}
当我点击它们时,按钮仍然有虚线焦点轮廓。
(是的,我知道这是一个可用性问题,但我想提供我自己的重点提示,这是适合于设计,而不是丑陋的灰点)
我可以让Firefox不显示丑陋的点状焦点轮廓的链接:
a:focus {
outline: none;
}
但我怎么能这样做<按钮>标签以及?当我这样做的时候:
button:focus {
outline: none;
}
当我点击它们时,按钮仍然有虚线焦点轮廓。
(是的,我知道这是一个可用性问题,但我想提供我自己的重点提示,这是适合于设计,而不是丑陋的灰点)
当前回答
button::-moz-focus-inner { border: 0; }
Where button可以是你想要禁用行为的任何CSS选择器。
其他回答
【更新】这个解决方案不再有效。对我有效的解决方案是https://stackoverflow.com/a/3844452/925560
标记为正确的答案在Firefox 24.0中无法使用。
为了移除Firefox在按钮和锚标记上的虚线轮廓,我添加了下面的代码:
a:focus, a:active,
button::-moz-focus-inner,
input[type="reset"]::-moz-focus-inner,
input[type="button"]::-moz-focus-inner,
input[type="submit"]::-moz-focus-inner,
select::-moz-focus-inner,
input[type="file"] > input[type="button"]::-moz-focus-inner {
border: 0;
outline : 0;
}
我在这里找到了解决方案:http://aghoshb.com/articles/css-how-to-remove-firefoxs-dotted-outline-on-buttons-and-anchor-tags.html
看起来实现这一点的唯一方法就是通过设置
browser.display.focus_ring_width = 0
在about:config中基于每个浏览器。
这将得到范围控制:
:focus {
outline:none;
}
::-moz-focus-inner {
border:0;
}
input[type=range]::-moz-focus-outer {
border: 0;
}
从:从Firefox的范围输入元素中删除点轮廓
与Bootstrap 3一起,我使用了这段代码。第二组规则只是撤销了bootstrap对焦点/活动按钮的作用:
button::-moz-focus-inner {
border: 0; /*removes dotted lines around buttons*/
}
.btn.active.focus, .btn.active:focus, .btn.focus, .btn.focus:active, .btn:active:focus, .btn:focus{
outline:0;
}
注意,你的自定义css文件应该在你的html代码中的引导css文件之后来覆盖它。
我认为你应该知道你移除焦点轮廓是在做什么,因为它会破坏键盘导航和可访问性。
如果你因为设计问题需要把它去掉,添加一个:focus状态到按钮上,用其他视觉提示替换它,比如,将边框更改为更亮的颜色或类似的东西。
有时我觉得有必要把烦人的轮廓去掉,但我总是准备一个替代焦点视觉线索。
永远不要使用blur() js函数。使用::-moz-focus-inner伪类。