我可以让Firefox不显示丑陋的点状焦点轮廓的链接:

a:focus { 
    outline: none; 
}

但我怎么能这样做<按钮>标签以及?当我这样做的时候:

button:focus { 
    outline: none; 
}

当我点击它们时,按钮仍然有虚线焦点轮廓。

(是的,我知道这是一个可用性问题,但我想提供我自己的重点提示,这是适合于设计,而不是丑陋的灰点)


当前回答

我试了这里的大部分答案,但没有一个对我有用。当我意识到我也必须去掉Chrome上按钮的蓝色轮廓时,我找到了另一个解决方案。删除蓝色边框从css自定义样式的按钮在Chrome

这段代码适用于Windows 7上的Firefox 30版本。也许这可以帮助到其他人:)

button:focus {outline:0 !important;}

其他回答

没错,别错过了,很重要

button::-moz-focus-inner {
 border: 0 !important;
}

我认为你应该知道你移除焦点轮廓是在做什么,因为它会破坏键盘导航和可访问性。

如果你因为设计问题需要把它去掉,添加一个:focus状态到按钮上,用其他视觉提示替换它,比如,将边框更改为更亮的颜色或类似的东西。

有时我觉得有必要把烦人的轮廓去掉,但我总是准备一个替代焦点视觉线索。

永远不要使用blur() js函数。使用::-moz-focus-inner伪类。

button::-moz-focus-inner { border: 0; }

Where button可以是你想要禁用行为的任何CSS选择器。

下面的CSS代码可以移除这个:

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;
}
button::-moz-focus-inner {
  border: 0;
}