我想知道是否有可能删除默认的蓝色和黄色发光,当我点击文本输入/文本区域使用CSS?删除Safari/Chrome textinput/textarea发光
回答
textarea, input, button { outline: none; }
虽然,它被认为保持发光/轮廓可访问实际有益的,因为它可以帮助用户了解哪些元素是目前的重点。
您还可以使用伪元素:focus
仅在用户选择它们时才将输入作为目标。
在基于WebKit浏览器的textarea调整大小:
上textarea的设置最大高度和最大宽度不会删除视觉调整手柄。尝试:
resize: none;
(是的,我同意“尽量避免做任何它打破了用户的期望”,但有时也有一定道理,即在web应用的上下文中)
要定制从头开始的webkit表单元素的外观和感觉:
-webkit-appearance: none;
此效果也可能发生在非输入元素上。我发现了以下工作为一个更通用的解决方案
:focus {
outline-color: transparent;
outline-style: none;
}
更新:您可能没有使用:focus
选择。如果你有一个元素,说<div id="mydiv">stuff</div>
,你都拿到这个div元素外发光,只适用于像正常:
#mydiv {
outline-color: transparent;
outline-style: none;
}
<select class="custom-select">
<option>option1</option>
<option>option2</option>
<option>option3</option>
<option>option4</option>
</select>
<style>
.custom-select {
display: inline-block;
border: 2px solid #bbb;
padding: 4px 3px 3px 5px;
margin: 0;
font: inherit;
outline:none; /* remove focus ring from Webkit */
line-height: 1.2;
background: #f8f8f8;
-webkit-appearance:none; /* remove the strong OSX influence from Webkit */
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
}
/* for Webkit's CSS-only solution */
@media screen and (-webkit-min-device-pixel-ratio:0) {
.custom-select {
padding-right:30px;
}
}
/* Since we removed the default focus styles, we have to add our own */
.custom-select:focus {
-webkit-box-shadow: 0 0 3px 1px #c00;
-moz-box-shadow: 0 0 3px 1px #c00;
box-shadow: 0 0 3px 1px #c00;
}
/* Select arrow styling */
.custom-select:after {
content: "▼";
position: absolute;
top: 0;
right: 0;
bottom: 0;
font-size: 60%;
line-height: 30px;
padding: 0 7px;
background: #bbb;
color: white;
pointer-events:none;
-webkit-border-radius: 0 6px 6px 0;
-moz-border-radius: 0 6px 6px 0;
border-radius: 0 6px 6px 0;
}
</style>
我发现它有助于去除在“拉门”大纲类型的输入按钮,因为轮廓不包括滑动门图像的右“帽”,使得聚焦状态看起来有点不可思议。
input.slidingdoorbutton:focus { outline: none;}
如果要删除从引导按钮辉光(这是不是在我看来一定是坏事UX),你需要下面的代码:
.btn:focus, .btn:active:focus, .btn.active:focus{
outline-color: transparent;
outline-style: none;
}
卡尔宽:
这种效果也可能出现在非输入元素上。我发现了以下工作为一个更通用的解决方案
:focus { outline-color: transparent; outline-style: none; }
我会解释这一点:
:focus
意味着它的风格是焦点中的元素。所以我们正在设计重点元素。outline-color: transparent;
表示蓝色发光是透明的。outline-style: none;
做同样的事情。
一些时候,它会发生按键也然后使用以下删除outerline
input:hover
input:active,
input:focus,
textarea:active,
textarea:hover,
textarea:focus,
button:focus,
button:active,
button:hover
{
outline:0px !important;
}
我只是需要从我的文字输入字段删除此效果,我不能让其他技术合作很对,但这对我来说很有用;
input[type="text"], input[type="text"]:focus{
outline: 0;
border:none;
box-shadow:none;
}
在Firefox和Chrome中测试。
我在div
上遇到过这种情况,它有一个点击事件,经过20次搜索后,我发现这段代码保存了我的一天。
-webkit-tap-highlight-color: rgba(0,0,0,0);
这禁用的WebKit的默认按钮高亮移动浏览器
这是人们做有关辅助护理解决方案。
请不要使用outline:none;
禁用焦点大纲。如果你这样做,你正在杀死网络的可访问性。有一个这样做的可访问的方式。
检查出this article,我已经写了解释如何以可访问的方式删除边框。
这个想法简而言之就是当我们检测到键盘用户时只显示轮廓边框。一旦用户开始使用他的鼠标,我们禁用轮廓。因此,你可以获得最好的两个。
当然!您也可以从所有的HTML元素使用删除蓝色边框*
*{
outline-color: transparent;
outline-style: none;
}
而且
*{
outline: none;
}
- 1. 在android中删除overscroll发光?
- 2. 通过删除光标
- 3. Android用光标删除行
- 4. 光油vcl_hash删除参数
- 5. iPhone:按下按钮时如何从UIBarButtonItem中删除发光(亮)?
- 6. 选中时从HTML文本输入中删除蓝色发光
- 7. 删除highcharts数据标签上的阴影/背景发光?
- 8. iOS如何从UISlider中删除发光/阴影
- 9. 删除Safari <select>发光但保留插入
- 10. 如何删除Video.js播放器模板上的按钮发光
- 11. 从Visual Studio 2012中删除窗口阴影/发光
- 12. 批量插入/删除使用光滑?
- 13. 从照片中删除眩光opencv
- 14. 使用光标删除记录
- 15. 从Android SQLite光标中删除行
- 16. 通过删除光标提高性能
- 17. 删除/更改拖放时的光标
- 18. Babylon.js删除球体的光线反射
- 19. 删除触发器
- 20. oracle触发删除
- 21. 删除后删除触发器只会触发吗?
- 22. 选择删除(高亮元素),除了输入#光标
- 23. 自定义鼠标光标删除重复的符号后,其中删除
- 24. 如何删除JavaFX按钮(选中时)的默认边框发光?
- 25. 删除`ItemListener`激发`ArrayIndexOutOfBounds`
- 26. 删除细胞发出
- 27. 无法删除触发器
- 28. 删除分发证书
- 29. 创建删除触发器
- 30. 级联删除通触发
我喜欢的蓝色光芒,觉得这恼人当人们将其禁用。在我看来,你应该禁用它的唯一时间是如果你正在修改文本字段的形状,并且蓝色辉光将出现在错误的地方。 – 2009-06-02 07:33:59
@Steve,禁用它的另一个原因是,如果你想通过使用:focus而不是不受支持的大纲样式来使所有浏览器都能使用发光效果。 – Langdon 2010-03-09 16:30:26
当问题是技术问题时,人们开始进行关于是否有“正确的事情”的哲学对话时,真的很烦人。 – tim 2013-03-22 19:31:28