去除按钮、链接边框黑线小结

 

也不算什么结吧,被人家总结得很全了,转一下,那个黑框确实很破坏页面美感,除之而后快!

前段时间在论坛上看到有关去除”链接/按钮”虚线框的讨论, 在这里把自己所知的方法记录一下, 并作出了对比.

方法一: IE 下使用expression(this.hideFocus=true), firefox下使用outline: none; (除了FF下对按钮不生效, 其它均有效) 代码:  
css:
.hideFocus{hide-focus: expression(this.hideFocus=true);}/* for ie 5+ */
.hideFocus{outline: none;}  /* for firefox 1.5 + */

html:
<a href="#" class="hideFocus">我是链接, 我不想要虚线</a>
<br/><br/>
<input type="button" value="我是按钮, 人家也不想要虚线嘛" />

这个方法的缺点是IE下使用expression, 增加了浏览器负担, 而且ff下对按钮也不能生效.

方法二: 使用js οnfοcus=blur(); 全生效;  代码:
css:

html:
<a href="#" onfocus="blur()">我是链接, 我不想要虚线</a>
<br/><br/>
<input type="button" value="我是按钮, 人家也不想要虚线嘛" onfocus="blur()" />

这个方法的优点是不需要写任何css代码, 也适应任何情况. 缺点是需要使用js, 而且”链接/按钮”会失去了focus状态, 在一些需要侦测”链接/按钮”focus状态的情况下, 会造成麻烦.

方 法三: 结合outline/border/zoom属性实现  代码:
css:

.hideFocus2{outline:0;zoom:1;}
.hideFocus2::-moz-focus-inner{border-color:transparent !important;}/* 让FF下button也生效 */

html:
<h3>方法三: 结合outline/border/zoom属性实现</h3>
<a href="#" class="hideFocus2">我是链接, 我不想要虚线</a>
<br/><br/>
<input type="button" value="我是按钮, 人家也不想要虚线嘛" />

这个方法暂时没看出有啥明显的缺点, 但暂时不是很清楚zoom:1;为什么就能让ie6去掉了虚线, 是因为促发了hasLayout吗? 这个问题以后搞清楚后, 会回来记录上.

PS:方法三学习自 “http://bbs.blueidea.com/thread-2929061-1-1.html” , 谢谢楼主分享!

 

原文地址:http://eosite.javaeye.com/blog/579171

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值