前端开发

 首页 > 前端开发 > css教程 > css加div使用小技巧一览

css加div使用小技巧一览

分享到:
【字体:
导读:
          本章主要介绍css加div使用小技巧一览。 正如多数人的认知一样,HTML和CSS并不难学难用,从学习曲线上来说确实如此,难度甚至不如使用VIM。但是写不写得好又是另一回事,好的CSS代码...

本章主要介绍css加div使用小技巧一览。

正如多数人的认知一样,HTML和CSS并不难学难用,从学习曲线上来说确实如此,难度甚至不如使用VIM。但是写不写得好又是另一回事,好的CSS代码能用最少的代码量实现功能,易修改且性能佳。易修改,举个最简单的例子,比如要求修改一个div的高宽且保持其子div自适应高宽,若是写死了子div的高宽,修改工作很麻烦,所以最好是将子div在需求下尽可能写成自适应,这样修改时就只需要修改父div的高宽即可。性能佳,能用CSS实现的绝对不用js实现,不管是网页布局还是动画效果,原生的CSS都是快速又具备高度兼容性的选择。

清除浮动


清除浮动是个常见问题,不少人的解决办法是添加一个空的 div 应用 clear:both。事实上仅需要使用after伪类即可在元素尾部自动清除浮动


.clear-fix { overflow: hidden; zoom: 1; }   
.clear-fix:after { display: table; content: ""; width: 0; clear: both; }

 


DIV同行排列

最容易想到的是将一行div全设置为display:inline-block,但这种做法会使得两个div之间存在“间隔”,这个“间隔”的大小通常由font-size决定。清除间隔可以通过使用注释的方法实现。

更好的方式自然还是使用float

.item {float: left}

灵活使用BFC


BFC(Block Formatting Context)直译为“块级格式化范围”。当一个HTML元素满足以下任何一点时,就会产生BFC:


    float的值不为none

    overflow的值不为visible

    display的值为table-cell, table-caption或inline-block

    position的值不为relative和static


BFC提供了一个环境,这个环境中的元素不会影响到其它环境中的布局。比如浮动元素形成BFC,浮动元素内部子元素的主要受该浮动元素影响,两个浮动元素之间是互不影响的。BFC就是一个作用范围,可看作是一个独立的容器,并且这个容器的布局,与这个容器外的元素毫不相干。


BFC的元素不能与浮动元素重叠,当容器有足够的剩余空间容纳 BFC 的宽度时,所有浏览器都会将 BFC 放置在浮动元素所在行的剩余空间内。

2015718182851156.png (516×42)


未垂直对齐


同一行的一组class为item的div使用了display:inline-block或者是float:left时,如果某个div的内部标签中填充一些文字等内容,可能就会出现垂直不对齐的情况。但非常奇怪的是,这时内部元素并没有超出父级div的范围,没有任何溢出或撑开的情况,这点我也不是很理解,知道其发生原因的同学欢迎留言。解决方法倒不难:


CSS

.item { vertical-align: top;}

 

display:table-cell的应用


table-cell会被其他一些CSS属性破坏,例如float和 position:absolute,所以display:table-cell与float:left或是position:absolute属性最好不要同用。设置了该属性的元素对宽度高度敏感,响应padding属性,对margin值无反应

垂直居中


.content {   
    display: table-cell;   
    border: 1px solid #eee;   
    width: 600px;   
    text-align: center;   
}   
  
   
    

what a beautiful day

   


两栏自适应布局


适用于一栏宽度不固定,比如大小不确定的图片,另一栏自动调整占满剩余宽度的场景。


.box {   
    width: 70%;   
}   
.content {   
    display: table-cell;   
    border: 1px solid #eee;   
}   
.fix {   
    float: left;   
    color: #a8c;   
}

  

   
    This is left fixed block
                    风住尘香花已尽,日晚倦梳头。物是人非事事休,欲语泪先流。闻说双溪春尚好,也拟泛轻舟。只恐双溪舴艋舟,载不动许多愁。           


分享到:
详解CSS中的规则声明
  CSS 规则由 选择器 和 声明 两部分组成,本文将要说的是第二部分:声明。 一个声明包含两部分:属性 和 值。 属性 指出要影响元素的哪个方面(颜色、高度,等等),而 值 表示属性设定为什么(绿色、15px,等等)。 CSS属性值主要分以下三类:     文本值    数字值    颜色值 1.文本值 文本值也叫关键字。所有...
css圆形和三角形小图标定义
参考了天猫、微博等网站的做法,用纯html和css实现,效果还是不错的。以下是成果,兼容主流浏览器,包括ie6。 以下是代码:                                            *{margin:0; padding:0; list-style:none; font:normal 12px/150% 宋体; }    body{ padding:...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……