CSS布局五大常见问题及解决方法

开发 前端
CSS布局有很多值得我们学习的地方,但是也容易出现一些小问题,这里和大家分享一下CSS布局五大常见问题及解决方法,希望对你的学习有所帮助。

本文和大家重点讨论一下CSS布局五大常见问题及解决方法,比如float的3像素问题及解决办法;上边容器浮动后,下边的容器跟着浮动,造成页面错乱;IE6下float浮动导致双倍边距的bug等内容。

CSS布局五大常见问题及解决方法

总结了5个关于CSS布局的常见问题,并附有解决方法,供参考。

◆float的3像素问题及解决办法

当使用float浮动容器后,在IE6下会产生3px的空隙,有意思的是右侧容器没设置高度时3px在右侧容器内部,当设定高度后又跑到容器的左侧了,所以对布局精度要求高的话,可以在float浮动容器样式里加针对IE6的属性”_margin-right”和”*html”,如:

  1. #sidebar{ float:left; width:200px; _margin-right:-3px;}  
  2.  

或者

  1. #sidebar{ float:left; width:200px;}  
  2. *html #sidebar{ margin-right:-3px;}  
  3.  

◆上边容器浮动后,下边的容器跟着浮动,造成页面错乱

 

如图中布局所示:footer必须要单独占一行,但当sidebar浮动后,content的高度小于sidebar的高度时,footer也跟着浮动到sidebar右侧了,造成页面错乱。解决办法是在maincontent和footer之间插入一个容器,设置样式
clear:both; height:0; font-size: 1px; line-height: 0px;用clear:both清除,即可使页面正常

◆IE6下float浮动导致双倍边距的bug

当页面内有多个连续浮动时,如本页的图标列表是采用左浮动,此时设置li的左侧margin值时,在最左侧呈现双倍情况。如外边距设置为10px,而左侧则呈现出20px,解决它的方法是在浮动元素上加上display:inline;的样式,这样就可避免双倍边距bug

◆当子元素浮动且未知高度时,怎么使父容器适应子元素的高度?

这种情况可在父窗口加上 overflow:auto;zoom:1;这两个样式属性,overflow:auto;是让父容器来自适应内部容器的高度,zoom:1;是为了兼容IE6而使用的CSS
HACK。zoom:1;通不过W3C的验证,这也是遗憾的一点,幸好IE支持这种写法,可以专门针对IE来写单独的样式,所以可以把这个属性写在页面内的中,这样应该可以通过验证了

◆CSS布局的相对定位与绝对定位

规划页面时,许多时候需要用到相对定位或绝对定位,这里边有个CSS技巧,掌握后有些地方就不用繁冗的js了。就是当父容器使用相对定位后,此时子元素再使用绝对定位,位置是相对于父元素。如果父元素没有定位,那么子元素的绝对定位是相对于浏览器

【编辑推荐】

  1. DIV CSS编码时必须注意的细节
  2. DIV+CSS隐藏内容行之有效的办法
  3. DIV CSS隐藏内容样式方法详解
  4. 九则技巧实现CSS网页布局中文排版
  5. DIV CSS网页布局需要掌握的八大技巧

 

责任编辑:佚名 来源: css3-html5.com
相关推荐

2010-09-07 13:24:18

CSS

2010-08-31 13:49:12

CSS

2009-08-24 10:37:11

Silverlight

2012-11-19 11:30:40

PowerShell常见问题解决方法

2011-05-06 17:25:58

硒鼓

2022-04-06 10:09:17

云服务云计算

2010-05-07 17:16:36

Unix系统

2018-11-01 15:26:38

开源软件安全

2018-12-26 08:00:00

CSS前端

2009-11-30 10:49:18

2010-08-31 16:09:04

DIV+CSS

2010-05-24 18:46:50

SVN图标

2023-10-26 08:16:20

C++线程

2010-08-18 15:02:54

IEFirefox兼容

2010-01-13 21:06:37

双绞线

2011-05-03 14:57:00

网络打印机常见问题解决方案

2020-05-15 22:47:22

电脑开机运行

2010-09-07 09:50:35

DIVCSS

2019-04-09 15:15:06

2010-07-29 15:44:54

Flex安全沙箱
点赞
收藏

51CTO技术栈公众号