html表格按钮怎么变大,CSS网页制作 表单button的行高问题

表单button的行高问题

下面我们先来看一个Demo的实例:

HTML Code

复制代码代码如下:

CSS Code

复制代码代码如下:

#button {

border: 2px solid #06f;

color: #06f;

background-color: #6cf;

font: bold 12px Arial, Helvetica, sans-serif;

line-height: 50px;

}

浏览器下的截图:

d1fade0d30e33c7646b0007bd122f705.png

多效果图中,明显的告诉我们,在Firefox和Opera浏览器中都存在问题,而且致命的一点是:“无论你通过什么手段去修改button的line-height,在Firefox和Opera浏览器下都无任何效果。”是什么导致的呢?(我以前从没注意到他们有这样的一个bug存在)。看了上面的文章我才知道,原来是浏览器对定义button的line-height是不同的,我们来看看浏览器在Firefox下的解析line-height值的截图:

70560146714bb0b15f784bddde9fa245.png

从图中告诉我们一个道理:button的行高在Chrome/Safari/IE8等浏览器解析正确的line-height(用户自定的值“50px”);而在Firefox和Opera解析的line-height却是默认的值,只有“15px”。那为什么会这样呢?

要回答这个问题,我回答不出来,可能您知道是为什么?我只能把他当作是Firefox和Opera浏览器下的一个特点,换句话就是:这两个浏览器的line-height默认值为normal并且还加了一个“!important”,类似于:

复制代码代码如下:

button, input[type="reset"], input[type="button"], input[type="submit"] {

line-height:normal !important;

}

那我们是不是可以在设置值的时候也加个“!important”解决呢?我尝试了,可是失败了,那我们需要怎么来解决呢?

如何解决?

Rob Glazebrook在他的《The Firefox Input Button Line-Height Bug》教程中使用了一种方法——在button中不重置line-height的值,而是使用padding来制作相同的效果。这样上面的实例可以这样修改:

复制代码代码如下:

#button {

border: 2px solid #06f;

color: #06f;

background-color: #6cf;

font: bold 12px Arial, Helvetica, sans-serif;

padding: 18px 6px;

}

这种办法让文本处在button的中心位置,虽然不是很理想,但我们又无法使用line-height来让他在中心点位置,不知道您有没有更好的方法。如果有的话,记得与我们一起分享。欢迎随时在评论中留言。

这个有关于button的line-height的bug不知道你以前留意了没,我是没有发现到,这次可算是学习了一下,那么最后在结束之前,我们一起感谢为之提供的技术链接,如果你还不太清楚我说的,而且你又对这个bug很感兴趣的话,你可以移步到Rob Glazebrook的《The Firefox Input Button Line-Height Bug》。希望对大家有所帮助。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值