日期:2013-12-02  浏览次数:21134 次

网页制造aiyiweb文章简介:表单button的行高问题。

HTML Code

<input type="submit" id="button" value="engage"/>

CSS Code

#button {

     border: 2px solid #06f;

     color: #06f;

     background-color: #6cf;

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

     line-height: 50px;

    }

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


从图中通知我们一个道理: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;

    }