CSS之创建等高列布局之一

高度相等列在Web页面设计中永远是一个网页设计师的需求。如果所有列都有相同的背景色,高度相等还是不相等都无关紧要,因为你只要在这些列的父元素中设置一个背景色就可以了。但是,如果一个或多个列需要单独设置自己的背景色,那么它的视觉完整性的设计就显得非常重要了。大家都知道当初Table实现等高列布局是多么的简单,但是我们使用CSS来创建等高列布局并非是那么容易的事情

如果一个设计是固定宽度(非流体的宽度设计),那么实现多列等高效果是相当的容易。最好的技术就是使用Dan Cederholm的Faux Columns技术。只要制作一张合适的背景图片,在你多列的父元素中进行垂直铺放,从而达到一种假像(假的多列等高布局效果)。但是在流体布局中要用CSS实现多列等高的设计那就不是那么容易的事情,因为我们没有办法在使用背景图片来实现多列等高的假像了,那么是不是就没有办法实现了呢?那当然不是那么回事了,不管是实现固定布局还是流体布局的等多列等高视觉效果,方法还是蛮多的,这些方法体现了CSS的不同技术,也各有千秋,下面我们就一起来探讨Web页面中的多列等高的实现技术

下面要介绍的方法都是让我们的布局如何实现多列的等高视觉效果,正如下图所示

这里写图片描述

方法1:假等高列

这种方法是我们实现等高列最早使用的一种方法,就是使用背景图片,在列的父元素上使用这个背景图进行Y轴的铺放,从而实现一种等高列的假像

HTML:

这里写图片描述

在制作样式之前需要一张类似下面的背景图:

这里写图片描述

CSS:

这里写图片描述

这里让外部容器背景在Y轴延伸背景,三列全部左浮动,但是缺点是不适合流体布局等高列的布局,另外如果你需要更换背景色或实现其他列数的等高列时,都需要重新制作过背景图

方法2:给容器div使用单独的背景色(固定布局)

这种方法实现有点复杂,如果你理解其实现过程也是相当的简单。这种方法我们主要给每一列的背景设在单独的<div>元素上。这种方法的实现的原则是:任何<div>元素的最大高度来撑大其他的<div>容器高度。如下图所示

这里写图片描述

上图中,不管我们哪一列的高度最高,那么其三个容器“rightBack,contentBack,leftBack”的高度相应会随最高列的高列变化,下面我们一起来看其实现过程

HTML:

这里写图片描述

CSS:

这里写图片描述

这里写图片描述

看起来蛮复杂吧?其实你只要了解了它是如何的工作原理就会变得非常简单,你只要理解并掌握以下几点

第一步:首先给’.rightWrap’和’.leftWrap’还有’.contentWrap’三个列容器设置浮动让其具备包裹性,同时设置其宽度跟父容器相同,最后在三个列都和父容器等宽的前提下分别向左移动一段距离,移动的距离就是你所要设置的列的宽度,又因为这三个容器是父子关系,所以子元素的高度变化必然导致父元素的高度一起变化,所以这样最后的效果看起来就是三个列横向排布,且等高的布局。

注意:到此已经实现了三个列等高的效果,但是因为内容还都是在外部的,所以此时添加内容后的效果不好,我们要做的就是将内容继续调整

这里写图片描述

这里写图片描述

这里写图片描述

我们发现包含内容的三个div都已经在外部,我们需要将它们调整回来,很明显现在的文字都在浅绿色容器内纵向排列,我们只要知道将浅绿色容器移动回来的值,那也就意味着知道了文字移动了回来的值,因为既然是父子容器那么必然是叠加的,上面的颜色层会改住下面的层,只是现在移动开了所以露出了下面的层,所以浅绿色移动回来的值等于它当初移动出去时候的距离’黄色的宽+深绿色的宽’,这里就是320+420=740px

第二步:给每个子元素设置浮动后再将其的固定宽度设置为之前父子容器偏移的固定距离,并且让其相对定位后偏移指定的距离即可(这个距离就是320+420),因为这里是相对定位所以哪怕前面的元素通过left移动走了,原来的空间还是要进行保留,再加上浮动让后面的元素本身就和前面的元素在同行显示

用两幅图来展示其实现的过程

下图是实现上面的第二步对应的示例图,也就是容器“div.rightWrap”,“div.contentWrap”,“div.leftWrap”进行相对定位(position: releative),并展示了如何设置对应的“right”值

这里写图片描述

上图虚线代表的范围是可视范围,其中有两列背景将会溢出,解决这个只需要在最外层容器“div.rightWrap”加上“overflow:hidden”就可以进行隐藏溢出的其他背景色。接下来下图所展示的是上面所说的第五步

这里写图片描述

前面我们对三个内容元素都进行了相对定位,现在只需要按第五步将其定位回去,如上图所示。其实说到最后,你只要理解了这两幅,你就什么都清楚了

缺点:这种方法不像其他方法一样简单明了,给你理解会带来一定难度,但是只要你理解清楚了,将能帮你创建任意列数的等高布局效果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407089.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一篇介绍VC开发OCX的文章,写得太棒了!!!

From: http://www.cnblogs.com/gengaixue/archive/2010/08/13/1799112.html VC2005从开发MFC ActiveX ocx控件到发布到.net网站的全部过程 开篇语&#xff1a;最近在弄ocx控件发布到asp.net网站上使用&#xff0c;就是用户在使用过程中&#xff0c;自动下载安装ocx控件。&…

使用webpack打包后的vue项目如何运行(express)

我们知道使用webpack打包vue项目后会生成一个dist文件夹&#xff0c;dist文件夹下有html文件和其他css、js以及图片等&#xff0c;那么打包后的文件该如何正确运行呢&#xff1f; 倘若直接打开html文件&#xff0c;会报如下错误&#xff1a; 那么该如何运行呢&#xff1f;其实…

CSS之创建等高列布局之二

3. 给容器div使用单独的背景色&#xff08;流体布局&#xff09; 这种布局可以说是就是第二种布局方法&#xff0c;只是这里是一种多列的流体等高列的布局方法。前面也说过了&#xff0c;其实现原理就是给每一列添加相对应用的容器&#xff0c;并进行相互嵌套&#xff0c;并在…

git 上传代码步骤

接下来 第一步&#xff1a;建立git仓库 cd到你的本地项目根目录下&#xff0c;执行git命令&#xff0c;此命令会在当前目录下创建一个.git文件夹。 git init 第二步&#xff1a;将项目的所有文件添加到仓库中 git add . 这个命令会把当前路径下的所有文件&#xff0c;添加…

CSS之创建等高列布局之三

4. 使用正padding和负margin对冲实现多列布局方法 这种方法很简单&#xff0c;就是在所有列中使用正的上、下padding和负的上、下margin&#xff0c;并在所有列外面加上一个容器&#xff0c;并设置overflow:hiden把溢出背景切掉。下面一起来看代码 HTML: CSS: 这里代码的关键…

git报错:‘fatal:remote origin already exists‘怎么处理?附上git常用操作以及说明。

git添加远程库的时候有可能出现如下的错误&#xff0c; 怎么解决&#xff1f; 只要两步&#xff1a; 1、先删除 $ git remote rm origin2、再次执行添加就可以了。   ----------------------------------------------git常用操作---------------------------------------…

CSS之两栏固定布局(一)

1. 固定布局之两栏布局——边栏在左边&#xff0c;主内容在右边 实现的布局效果&#xff1a;整个布局居中显示&#xff0c;而且侧栏显示在左边&#xff0c;主内容在右边 HTML&#xff1a; - div.wrapper是主容器&#xff0c;以960px为例&#xff0c;并且居中显示 - div.heade…

CSS之两栏固定布局(二)

3. 负margin布局 3.1 HTML: - 页面分为三个部分&#xff0c;头部&#xff08;div#header&#xff09;、主体&#xff08;div#page&#xff09;、脚部&#xff08;div#footer&#xff09;&#xff0c;同样在这三个容器中使用了内容器&#xff08;div.container&#xff09;用来…

CSS之Flexbox制作CSS布局易如反掌

伸缩盒模型&#xff08;flexbox&#xff09;是一个新的盒子模型&#xff0c;主要优化了UI布局。作为实际布局的第一个CSS模块&#xff08;浮动真的应该主要用来制作文本围绕图片这样的效果&#xff09;&#xff0c;它使很多任务容易多。Flexbox的功能主要包手&#xff1a;简单使…

配置Log4j(非常具体)

来自: http://www.blogjava.net/zJun/archive/2006/06/28/55511.html Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的&#xff0c;它可接keyvalue格式的设置或xml格式的设置信息。通过配置&#xff0c;能够创建出Log4J的执行环境。1. 配置文件L…

产品设计体会(2011)网络推广实战

产品做出来&#xff0c;推广和运营非常重要&#xff0c;很多老板眼里和心里&#xff0c;做这些事情的部门才是“利润中心”&#xff0c;而辛辛苦苦的产品、研发部门&#xff0c;则都是“成本中心”。有人说史玉柱是最好的产品经理&#xff0c;他强就强在对用户、市场、产品的了…

纯CSS实现锚点跳转位置上下偏移的办法

昨天在sf的时候看到了一位朋友的提问&#xff0c;是问如何使页面上的a标签被点击时跳转的锚点的位置往下偏移一点&#xff0c;不会被最上方的header给遮盖。当时看到这个问题也没想出纯CSS的解决方法&#xff0c;以为只有用js才能实现&#xff0c;后来另一位朋友的解答&#xf…

[oralce] 利用CRT的端口转发功能直接用plsql访问数据库

From: http://blog.sina.com.cn/s/blog_498a6eeb0100w197.html 如图所示&#xff1a;在实际中经常碰到上面的情况&#xff0c; 要访问生产上的数据库必须通过跳转机&#xff0c; 而且只能用sqlplus来访问&#xff0c;很不方便&#xff0c;而且为了安全&#xff0c;一般情况下不…

[转载]如何做到 jQuery-free?

http://www.ruanyifeng.com/blog/2013/05/jquery-free.html jQuery是现在最流行的JavaScript工具库。 据统计&#xff0c;目前全世界57.3%的网站使用它。也就是说&#xff0c;10个网站里面&#xff0c;有6个使用jQuery。如果只考察使用工具库的网站&#xff0c;这个比例就会上升…

CSS之flex需要知道的一切(一)

1.flex速记 1.1 flex: 0 1 auto 很容易理解这一点&#xff0c;flex-basis设置为auto&#xff0c;这意味着Flex项目的初始宽度计算是基于内容的大小来自动变化 flex-grow设置为0&#xff0c;这意味着flex-grow不会改变Flex项目的初始宽度&#xff0c;也就是flex-grow的开关是…

win7 安装 IIS

和xp不同,xp安装 IIS需要下载额外的软件包. 步骤 1,依次打开 "控制面板" -> "程序" ->"打开或关闭windows功能": 2,安装图示选择: 确定即可.转载于:https://www.cnblogs.com/listened/p/4014762.html

如何处理Oracle客户端查询乱码问题

From: http://archive.cnblogs.com/a/2074122/ 1&#xff0c;查Oracle数据库创建时候的字符集&#xff1a;Oracle服务器端执行SQL> select name, value$ from sys.props$ where name like NLS%;NAME VALUE$------------------------------ -------------------------------…