在使用pureCSS框架的时候,遇到一个问题。 input输入框,我给他们设置了宽度和padding值,我发现,在火狐和谷歌上面发现,增长padding值并不会影响最终的宽度,而在IE6 7下则会影响宽度。后来发现是pure框架为输入框设置了box-sizing致使(IE6 7不支持),我得分别设置不一样的宽度。 因此,在使用这个框架的时候, 为了统一,应该设置 input[type=text] { box-sizing : content-box; -moz-box-sizing : content-box; }
css
如下是查找的资料: 来源: http://segmentfault.com/q/1010000000413229web
input文本框输入内容须要缩进,使用text-indent和padding-left有哪些区别,用哪一个好?chrome
总的来讲,text-indent
不影响元素的最终宽度可是有兼容性问题,padding-left
在中国主流浏览器IE低版本下影响最终宽度,但在chrome和firefox下不影响宽度,可是能够经过CSS reset解决多浏览器显示不一的问题,使得他们最终都影响宽度。segmentfault
text-indent
和padding-left
的基本区别:浏览器
padding-left
基于盒模型,适用于inline和block层级的元素text-indent
基于行内排版,仅仅适用于block层级的元素,做用于block层级的元素的内部第一行文字几乎他们全部的表现区分都是这两者的区分。框架
padding-left
会做用于inline框
或block框
的左侧padding区域,会影响到content-box,而文字子节点会出如今content-box内部,所以全部文字都会左移。spa
text-indent
会做用于block框
的第一行文字。不管是文字超过容器的宽度被white-space
的相应规则截断,仍是文字中的回车被white-space
的相应规则保留,最终致使第二行第三行第N行出现,后面的第二行第三行第N行都不会应用到相应的indent。text-indent
的目的很纯净,就是为了模拟现实排版需求中的首行缩进效果。.net
http://jsfiddle.net/humphry/3bSSX/firefox
<input type="text">
做为一个inline-block层级的标签,它是固定单行显示的(并且还和white-space
机制不同),上面所述区别并不存在。code
那么区别在哪里呢:
text-indent
基于行内排版,致使应用了direction: rtl
以后,text-indent
提供的indent出如今右侧;padding-left
则不受direction
影响。
固然,direction
这个属性不经常使用于<input type="text">
padding-left
基于盒模型,因此box-sizing
属性会和padding-left
、width
属性一同影响到元素的最终宽度;而text-indent
则始终不会影响元素的宽度。
这很重要,由于webkit和firefox的默认样式表里,会设置input元素的box-sizing: border-box
,若你同时设置了width
和padding-left
,会出现webkit/firefox和IE低版本的很大的宽度区别。
所以,用到padding-left
时,须要重置webkit和firefox的相应样式:
input[type=text] { box-sizing : content-box; -moz-box-sizing : content-box; }
重置样式以后,在全部浏览器里面,有效的padding-left在全部状况均会加到元素的最终宽度上,如上面jsfiddle所示。这是须要额外考虑的事情。