浏览器可能加入的兼容限制(如何处理的浏览器兼容性)

在前端工作中用input做一个按钮,文本输入框禁之类东西,由于浏览器的兼容性问题,让前端人员头疼不已,那如何解决,本文章以下部分介绍:

input标签在各浏览器里默认高度和宽度:

当input标签在type为text时,在Firefox和Safari中的默认高度为22像素(包括上下边框)宽度为146像素(包括左右边框),而在IE中的默认高度为24像素,而宽度却和Firefox和Safari是一致的,也是146像素。

当 input标签在type为submit时,在Firefox中的高度为23像素(包括阴影),宽度为75像素。在Safari中高度为21像素,宽度为73像素,在IE中高度为为25像素、宽度为73像素。

以上问题我们应该如何来处理呢?可以拿淘宝首页的搜索框来说下:

浏览器可能加入的兼容限制(如何处理的浏览器兼容性)(1)

在不同浏览器中都有着良好表现的搜索框,它设置了高度和行高都为18px,然后设置了padding属性。

然后去把高度和行高去掉了,通过调节padding属性一样可以达到效果,这样既减少了CSS代码又实现了效果,两全其美啊。

通过上面的例子,我总结了下关于input标签处理兼容问题的方法:

1、不要给属性为text的input标签设置高度,这样无法让IE浏览器下输入框中的文字垂直居中显示。尽管你后来想要通过设置padding属性来让文字居中,你会发现根本没法让它在Firefox和IE中取得一致的效果。正确的做法是直接给input标签设置padding属性,通过内边距属性来调节input标签的高度,而且这时IE中的文字也是居中显示的。

2、input标签不会继承父元素的字体样式和大小,需要直接给input标签声明font-family和font-size属性。

3、给属性为text的input标签设置合适的width属性和padding属性,确保其中的文字在合适的范围内出现。尤其是使用了背景图片后,要让文字框的大小和背景图片的大小相当,这样看上去更加美观。

最后总结一下, 上面只是我对input搜索框的一些看法,至于input与文字混排对其的问题跟这个类似,只不过要增加一个绝对居中vertical-align:middle的属性,就不多讲了。最后只想说:细节往往能体现你的技术含量,细节也有可能导致一个项目的成败,对于这些小问题,我们不能忽视之。

切图网(qietu.com)是一家专门从事web前端开发的公司,专注we前端开发,关注用户体验,欢迎订阅qietuwang

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页