标签:text 通用 sid 没有 模式 盒子宽度 之间 日期 大于
对于行内元素,height会自己主动收缩到包裹住文本的高度,所以不存在这个问题。
可是对于block和inline-block等盒子元素。假设设置了height属性,则文本默认会在上方显示。
假设希望文本在垂直方向上居中,能够设置line-height属性等于height属性。或者大于height属性
<div>
hello world
</div>div {
height: 200px;
line-height: 200px;
}效果是左側一个小箭头,右側一个小箭头,日期显示在中间
<div id="wrapper">
<span><</span>
<span>2014年5月11日</span>
<span>></span>
</div>#wrapper{
text-align: center;
position: relative;
width: 200px;
}
#wrapper > span:first-child{
float: left;
}
#wrapper > span:last-child{
float: right;
}一般来说。行内元素(如span)。会自己主动收缩以适应文本宽度,为其设置width属性是无效的。可是当span元素被float了之后。就能够为其设置width属性了
对于块元素,如block和inline-block。假设不设置其width。则会自己主动扩展到父容器的宽度。此时设置它的padding和border,不会改变盒子的大小(还是和父容器一样宽),可是会缩小content的宽度
<div id="parent">
<div id="son">abc</div>
</div>
#parent {
widht: 200px;
}
#son {
padding: 1px;
border: 1px solid black;
}假设设置了son的width。实际上设置的是content的width。加上border和padding后,实际的宽度会超过父容器
#son {
width: 200px;
padding: 1px;
border: 1px solid black;
}可是,假设设置box-sizing为border-box。则设置的width就变成了整个盒子的宽度,此时再设置border和padding。又会缩小content的宽度了
#son {
box-sizing: border-box;
width: 200px;
padding: 1px;
border: 1px solid black;
}<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>ul{
font-size: 0;
}
li{
font-size: 1rem;
display: inline-block;
width: 20%;
}有点类似上面的li平铺
<div>
<nav></nav>
<div></div>
<aside></aside>
</div>div {
font-size: 0;
}
div > * {
display: inline-block;
font-size: 1rem;
vertical-align: top;
}
div > nav {
width: 30%;
}
div > div {
width: 50%;
}
div > aside {
width: 20%;
}否则当各子元素的高度不一致时。看起来似乎没有在同一行。其有用dev tools能够看出来,3个子元素还是在同一行,仅仅是在垂直方向上没有对齐。设置vertical-align能够解决此问题
<div>
<nav></nav>
<div></div>
<aside></aside>
</div>div {
display: -webkit-box;
}
div > nav {
width: 200px;
}
div > div {
-webkit-box-flex: 1;
}
div > aside {
-webkit-box-flex: 2;
}长处是不会出现1px问题。也不须要设置子元素为inline-block。非常方便。另外。设置display: box之后,子元素会自己主动变成等高。
这在某些场景下非常方便,可是也不适用于另外一些场景。最后display: box,在老的浏览器上支持不好,所以这样的方式没有老技巧那么通用。可是随着浏览器日趋标准,我认为慢慢就不是问题了
标签:text 通用 sid 没有 模式 盒子宽度 之间 日期 大于
原文地址:http://www.cnblogs.com/yutingliuyl/p/6962248.html