• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 一波CSS+Div实用技巧小结

一波CSS+Div实用技巧小结

作者:quietin 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,Div等相关知识,quietin 希望在学习及工作中可以帮助到您

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

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

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

DIV同行排列

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

  1. <div class="item"></div><!--   
  2. --><div class="item"></div>  

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

  1. .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的范围,没有任何溢出或撑开的情况,这点我也不是很理解,知道其发生原因的同学欢迎留言。解决方法倒不难:

  1. .item { vertical-align: top;}  

display:table-cell的应用

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

  1. .content {   
  2.     display: table-cell;   
  3.     border: 1px solid #eee;   
  4.     width: 600px;   
  5.     text-align: center;   
  6. }   
  7.   
  8. <div class="content">   
  9.     <p>what a beautiful day</p>   
  10. </div>  

两栏自适应布局

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

  1. .box {   
  2.     width: 70%;   
  3. }   
  4. .content {   
  5.     display: table-cell;   
  6.     border: 1px solid #eee;   
  7. }   
  8. .fix {   
  9.     float: left;   
  10.     

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06Web前端开发规范文档(css/javascript)
  • 2017-08-06推荐10个CSS3 制作的创意下拉菜单效果
  • 2017-08-06css 空白外边距互相叠加的解决方法
  • 2017-08-06父元素与子元素之间的margin-top问题(css hack)
  • 2017-08-06CSS实现自适应宽度的菜单按钮效果代码
  • 2017-08-06css ID类和class类的长命名与短命名
  • 2017-08-06CSS更改鼠标为手状样式
  • 2017-08-06CSS控制页面最大最小宽度和高度可兼容IE6版本的实现方法
  • 2017-08-06在支持HTML5的浏览器上运行WebGL程序的方法
  • 2017-08-06利用css代码实现纸飞机效果实例源码

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 基于html和CSS3制作酷炫的导航栏
    • 老生常谈css中float的用法
    • css实现的圆角效果带有注释
    • CSS中值得记住的一些技巧
    • CSS各种居中布局方法汇总
    • 详解CSS3 Media Queries中媒体属性的使用
    • web开发中的一些技术杂项整理文章
    • 英文强制换行css 使用css强制英文单词断行代码
    • css3闪亮进度条效果实现思路及代码
    • IE 元素默认高度研究

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有