zoukankan      html  css  js  c++  java
  • 解决input宽度设置成100%与padding的冲突

    一、问题描述

    我是流体布局控,经常会遇到文本框以及文本域宽度100%自适应显示的情况。

    如下效果图:
    文本域宽度100%显示 张鑫旭-鑫空间-鑫生活

    在窄屏下,上面的文本框宽度也要跟着外部宽度变小。

    难点
    对于文本框或者文本域,光标最好距离左侧边缘有一定的间距。因此,我们基本上都有类似下面的设置:

    input { padding-left: 10px; }

    但是,如果只考虑文本框本身(父标签无其他特殊处理),这一套在流体环境下是行不通的,因为固定的padding数组无法让文本框永远100%自适应外部的宽度,至少非现代浏览器下是如此!//zxx: CSS3计算(calc())就是为了解决这类问题才诞生的!

    input {  calc(100% - 10px); padding-left: 10px; } 

    目前而言,好的解决之道是widthpadding均采用百分比值,例如下面这样:

    input {  92%; padding-left: 4%; padding-right: 4%; }

    问题
    上面这种写法,IE6+, Opera, Chrome, Safari浏览器都是显示很OK的;唯独FireFox火狐浏览器,其虽然宽度渲染正常,但是,光标的位置确是顶头的(与数值padding的显示完全不同)。

    如下截图:
    FireFox下面文本框百分比padding显示的问题截图

    这个问题再FireFox浏览器下存在已经有3年之久了,到现在还没有修复。您可以狠狠地点击这里:FireFox下文本框百分比padding位置bug demo

    更新2012-11-30

    注意:FireFox 17+已经修复了该问题!

    二、box-sizing的修复策略

    FireFox下文本框或文本域对百分比padding值的显示有问题,但是对具体px的padding值显示却正常。因此,我们可以设置padding-left/padding-right为类似10px这样的具体数值,而把问题解决的重心放在如何宽度100%显示上。

    在CSS3属性中,有个叫做box-sizing的好东西,IE8+以及现代浏览器都支持,如果我们设置该属性值为border-box,则padding值不会撑大元素的设定宽度,如100px; padding:10px;最后元素占据的宽度还是100像素而不是120像素。

    于是,这里,我们可以如下设置CSS:

    input:-moz-read-write{100%; height:40px; padding:10px; -moz-box-sizing:border-box;}

    FireFox即问题修复,如下截图:
    box-sizing修复后的FireFox浏览器截图 张鑫旭-鑫空间-鑫生活

    您可以狠狠地点击这里:box-sizing修复FireFox文本框百分比宽度问题demo

    四、CSS3 cacl()计算修复

    上面的box-sizing方法影响到了原本OK的height设置,而使用CSS3 cacl()计算只针对目标属性width进行处理,如下修复代码:

    input:-moz-read-write{-moz-calc(100% - 20px); padding:10px;}

    注意,减号(-)前后需要有空格,否则无法识别。

    于是,有大致如下的修复效果图(FireFox浏览器截图):
    CSS3 cacl()计算修复后的FireFox浏览器截图 张鑫旭-鑫空间-鑫生活

    您可以狠狠地点击这里:box-sizing修复FireFox文本框百分比宽度问题demo

    五、文本框文本域含边框时的处理

    到目前为止所示的情况都是不含边框的,基本上,全世界90%+的文本框或者是文本域都是有border的,或自身的或CSSer设置的,要知道,border是不支持百分比宽度的,只能是固定数值大小的单位。现在问题来了:含有border的文本域文本框如何实现宽度100%的自适应呢??

    使用padding正值+margin负值补间技术
    //zxx: 这里的内容有些偏题,不过多展开。

    demo抢先,您可以狠狠地点击这里:文本域(含边框)的宽度100%显示demo

    固定数值与文本域100%宽度显示截图缩略图

    demo中,上面一个例子是仅边框是固定像素值;下面一个是边框以及左右padding都是固定数值。都实现了良好的100%自适应,兼容IE6以及IE7浏览器。

    原理(见下图圈中,不言而喻):

    然而,在实际的项目中,我并不经常使用上面的方法。一是牵扯父标签;二是牵扯计算;三是无法大范围重用(原因是父标签的padding值设置受限)。

    OK,到此为止,感谢阅读,欢迎指正文章表述不准确的地方,吃饭饭去咯~

     

  • 相关阅读:
    javascript权威指南(2)
    javascript权威指南(1)
    java之jvm学习笔记四(安全管理器)
    JavaEE Tutorials (2)
    Java高效编程(2) -- Creating and Destroying Objects
    JavaEE Tutorials (1)
    Java Web整合开发(12) -- JDBC
    memcached安装和验证
    [leetcode]Two Sum
    Java Web整合开发(11)
  • 原文地址:https://www.cnblogs.com/screw/p/5219259.html
Copyright © 2011-2022 走看看