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

CSS 三栏等高布局实现方法

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

本文主要包含CSS,三栏等高,布局等相关知识,佚名 希望在学习及工作中可以帮助到您
首先,三栏等高布局,顾名思义,可以概括为以下特征:
1、3列(白痴也知道)
2、这3列高等相等
3、这3列的高度不是固定不变,而是随着内容的变化而变化

Step 1:
xhtml代码:

主要结构式#container的div,至于#header和#footer,完全是为了让它能够更像网页一些,回到#container,它内部包含三列,其中main里包含的是一个网页最核心,最主要的内容,所以我们不能怠慢,在纯xhtml的流文档中,浏览器是从上到下解析的,故重要的内容应该放在比较靠前的位置,这是由搜索引擎的权重决定的吧,但是视觉上,我们待会儿会把它放到中间。

思考一下:这三列怎么可能在没有写死高度的时候还智能的齐头并进呢?
其实不写死高度的确不能办到智能的齐头并进,那怎么写死高等呢,答案就是,利用盒模型,写它的padding,这是一种变态的方法,但挺奏效,就好比一个人 只有实际只有170cm,但是算上20cm的头发,天啊,他已经是190cm了,还是先给出解决方法吧:就是利用padding-bottom和margin-bottom;

Step2:

Step3:

这一步应该算是本主题的核心,至于32767 这个数你可以理解成“足够大”,以便于有足够的空间去扩展它的盒子,这么高应该是巨人症吧,没关系,我们可以用margin-bottom的负值去隐藏它,这个技巧,在我看来,我真的解释不清楚,有句古话: 意会,言传!  你只要试试看,就会领会到其中的奥妙。下边这幅图对你的理解应该有帮助:

到了这步,你会发现这3列的盒模型为32767px,此时你要在父元素上加:overflow: hidden;当然IE6.0是:zoom:1;

Step4:
现在#main的视觉效果是在最左栏,我们要想办法把它搞成中间
思路:先把#main排到中间,我们可以#main{margin-left:300},这时,#left被挤到800px的位置,在#left{margin-left:-800px;}就能搞定,可惜啊,IE6这个贱货,实在是无语,只得重新思考了。

一般的,在css做布局时,有几种思路,一种是float,一种是定位,关于定位的话,不熟悉的google一下就行,提一下:position: relative;的这个属性,如果不指明top,left的话,它的视觉效果不会改变。
所以,为了让#main在视觉效果上有所突破,那么必须指明top或者left,在这里只需要指明left就行了,

其实在这中间,还有一个概念是比较重要的,#main,#left有了position:relative以后,就有了层的概念,所以当#main{left:300px}后,#left已经独立出来了,不会被挤到800px的位置了,故:之需要left:-500px就能达到左边,500是#main的宽。
最后考虑的是向下兼容,
提供一段代码:

虽然写了这么多,但是你能够做,并不代表你应该这么做,这是一个战术和战略的问题,以下是我个人想知道的:
我觉得一开始:

这么大的值,在reflow阶段会不会很耗资源,而采用js来控制他们的高度,会不会来得更轻松一些呢?

第一次写这种东东,感到很棘手,不管是构思上还是在语言表达上都还是很晦涩的,希望大家积极的指正,希望能和更多的朋友来进行交流,一方面是提高自己,另一方面是促进社区的和谐和共享,尽一份自己微薄的力量。

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

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

相关文章

  • 2017-08-24完整css选择器总结
  • 2017-08-06CSS之Position全面认识
  • 2017-08-06表格的头部固定效果通过css及jquery分别实现
  • 2017-08-06CSS3 animation实现逐帧动画效果
  • 2017-08-06CSS3媒体查询Media Queries基础学习教程
  • 2017-08-06浏览器默认样式
  • 2017-08-06IE6下Select元素被div等元素覆盖的解决办法
  • 2017-08-06利用负边距技术制作自适应宽度布局的网页
  • 2017-08-06css的几种以图换字方式小结
  • 2017-08-06独行DIV自适应宽度布局CSS实例与应用范围

文章分类

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

最近更新的内容

    • css ul li导航菜单居中问题解决方法
    • CSS Border属性制作小三角
    • FORM 不换行的方法
    • Div+CSS 规则整理 提高效率
    • 页面内嵌样式表中使用url(), 出现页面多次载入问题解决
    • CSS 英文教程 CSS语法
    • css中margin:0 auto居中问题深入探讨
    • CSS 文本字体颜色设置方法(CSS color)
    • 使用CSS3实现圆角,阴影,透明
    • 实例讲解如何使用CSS保持页面内容宽高比

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

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