CSS布局 ——从display,position, float属性谈起

  页面布局,或者是在页面上做些小效果的时候经常会用到display,position和float属性,如果对它们不是很了解的话,很容易出现一些莫名其妙的效果,痛定思痛读了《CSS Mastery》后总结一下。

  让我们从基础的CSS知识谈起,相信很多初学者和小弟一样不明白CSS原理,一味追求效果,结果页面漏洞百出,错误匪夷所思,关于盒模型我就不多说了,网上很多,注意一下IE和其他浏览器(W3C规范)的区别就好了。

  块级元素与行内元素

  首先谈谈人们经常提及的块级元素和行内(内联)元素

  p,ul,form,div等元素被称为块级元素,这些元素显示为一块儿内容(会自动换行),span,input等元素称为行内元素,这两者主要区别就是块级元素会从上到下一个个垂直排列,每个自占一行,如下即使两个div之间没任何元素,绿色的div仍然会显示在hongsediv下方,而不是右方

<div style="height: 100px; width: 100px; background-color: Red;">
</div>
<div style="height: 100px; width: 100px; background-color: Green;">
</div>

  而行内元素在一行中水平排列,行内元素的高度由其内容撑开,不可显示的设置其高度,这就是为什么我们一次次的在span上设置height属性不好使的原因。

  简单了解了这些知识,让我们看看display常用的几个属性,一些不太常用的我也不明白,就不说了

描述
none

此元素不会被显示。

block

此元素将显示为块级元素,此元素前后会带有换行符。

inline

此元素会被显示为内联元素,元素前后没有换行符。

inline-block

行内块元素。(CSS2.1 新增的值)

  我们在显示隐藏元素的时候经常会用到把display设为none或者’’,设为none效果很明显,就是让元素脱离文档流,不显示,不占文档空间,而设为’’其实就是设置为元素默认属性block或inline,inline-block属性是CSS2.1新加值,IE8以上及其他主流浏览器都已经支持,它可以使元素像行内元素那样水平一次排列,但是框的内容符合块级元素行为,能够显示设置宽,高,内外边距。很有意思。

  还有一点儿很有意思,可以通过不同的赋值改变元素生成框的类型,也就是说,通过将display属性设置为block,可以使行内元素表现的想块级元素一样,反之亦然。

  定位

  要想了解CSS元素定位就需要了解position属性了,position属性有几个常用值如下

属性
inhert

规定应该从父元素继承 position 属性的值。

static

默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。

relative

生成相对定位的元素,相对于元素本身正常位置进行定位。因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。

absolute

生成绝对定位的元素,相对于 static 定位以外的第一个祖先元素进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

fixed

生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

  CSS有三种基本的定位机制:普通流,浮动和绝对定位

  普通流是默认定位方式,在普通流中元素框的位置由元素在html中的位置决定,元素position属性为static或继承来的static时就会按照普通流定位,这也是我们最常见的方式。

  相对定位比较简单,对应position属性的relative值,如果对一个元素进行相对定位,它将出现在他所在的位置上,然后可以通过设置垂直或水平位置,让这个元素相对于它自己移动,在使用相对定位时,无论元素是否移动,元素在文档流中占据原来空间,只是表现会改变。

  普通流:

<div style="border: solid 1px #0e0; width:200px;">
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
</div>

  相对定位:

<div style="border: solid 1px #0e0; width:200px;">
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green; position:relative; top:20px; left:20px;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
</div>

  上面例子可以看出,对绿色div进行相对定位,分别右移,下移20px后第二个红色div位置并没有相应变化,而是在原位置,绿色div遮挡住了部分红色div。

  相对定位可以看作特殊的普通流定位,元素位置是相对于他在普通流中位置发生变化,而绝对定位使元素的位置与文档流无关,也不占据文档流空间,普通流中的元素布局就像绝对定位元素不存在一样。

  绝对定位的元素的位置是相对于距离他最近的非static祖先元素位置决定的。如果元素没有已定位的祖先元素,那么他的位置就相对于初始包含块儿(body或html神马的)元素。

  因为绝对定位与文档流无关,所以绝对定位的元素可以覆盖页面上的其他元素,可以通过z-index属性控制叠放顺序,z-index越高,元素位置越靠上。

  还是刚才的例子,稍微改动一下,让绿色div绝对定位,为了清晰显示,第二个红色div改为黄色。

<div style="border: solid 1px #0e0; width:200px; position:relative;">
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green; position:absolute; top:20px; left:20px;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;">
	</div>
</div>

  这时可以看出,绿色div是相对于父元素,也就是绿框div进行的移位,而红色和黄色div进行布局时就像绿色div不存在一样。

  最后要说的就是fixed属性了,应用fixed也叫固定定位,固定定位是绝对定位的中,固定定位的元素也不包含在普通文档流中,差异是苦丁元素的包含块儿是视口(viewport),经常见一些页面的如人人网看在线好友那个模块总在窗口右下角,估计用的是类似技术

  固定定位:

<div style="border: solid 1px #0e0; width:200px;">
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green; position:fixed; bottom:20px; left:20px;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;">
	</div>
</div>

  

  可见hongse和黄色div布局没有受到绿色div影响,而无论是页面纵向滚动条在页面顶端还是底端,绿色div总是在视口左下角

  浮动

  首先介绍一些浮动模型的基本知识:浮动模型也是一种可视化格式模型,浮动的框可以左右移动(根据float属性值而定),直到它的外边缘碰到包含框或者另一个浮动元素的框的边缘。浮动元素不在文档的普通流中,文档的普通流中的元素表现的就像浮动元素不存在一样.《CSS Mastery》里作者画了几个图非常有意思,可以帮助我们理解浮动的表现,我简单的画几个。

  不浮动

<div style="border: solid 5px #0e0; width:300px;">
	<div style="height: 100px; width: 100px; background-color: Red;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green; ">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;">
	</div>
</div>

  红向右浮动

<div style="border: solid 5px #0e0; width:300px;">
	<div style="height: 100px; width: 100px; background-color: Red; float:right;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green; ">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;">
	</div>
</div>

  红框左移,覆盖绿框

<div style="border: solid 5px #0e0; width:300px;">
	<div style="height: 100px; width: 100px; background-color: Red;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;">
	</div>
</div>

  都向左浮动,父元素宽度为0

 <div style="border: solid 5px #0e0; width:300px;">
 	<div style="height: 100px; width: 100px; background-color: Red;  float:left;">
 	</div>
 	<div style="height: 100px; width: 100px; background-color: Green;  float:left;">
 	</div>
 	<div style="height: 100px; width: 100px; background-color: Yellow;  float:left;">
 	</div>
 </div>

  如果包含块儿太窄无法容纳水平排列的三个浮动元素,那么其它浮动块儿向下移动,,直到有足够的扣减,如果浮动元素的高度不同,那么下下移动的时候可能被卡住

<div style="border: solid 5px #0e0; width:250px;">
	<div style="height: 100px; width: 100px; background-color: Red;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;  float:left;">
	</div>
</div>

  卡住了

<div style="border: solid 5px #0e0; width:250px;">
	<div style="height: 120px; width: 100px; background-color: Red;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;  float:left;">
	</div>
</div>

  行框和清理

  前面指出浮动会让元素脱离文档流,不影响不浮动元素.实际上并不完全如此,如果浮动的元素后面有一个文档流中元素,那么这个元素的框会表现的像浮动元素不存在,但是框的文本内容会受到浮动元素的影响,会移动以留出空间.用术语说就是浮动元素旁边的行框被缩短,从而给浮动元素流出空间,因而行框围绕浮动框。

  不浮动

<div style="border: solid 5px #0e0; width: 250px;">
	<div style="height: 50px; width: 50px; background-color: Red;"></div>
	<div style="height: 100px; width: 100px; background-color: Green;">
		11111111111
		11111111111
	</div>
</div>

  浮动

 <div style="border: solid 5px #0e0; width: 250px;">
 	<div style="height: 50px; width: 50px; background-color: Red; float:left;"></div>
 	<div style="height: 100px; width: 100px; background-color: Green;">
 		11111111111
 		11111111111
 	</div>
 </div>

  可以看出浮动后虽然绿色div布局不受浮动影响,正常布局,但是文字部分却被挤到了红色浮动div下边。要想阻止行框围绕在浮动元素外边,可以使用clear属性,属性的left,right,both,none表示框的哪些边不挨着浮动框。

<div style="border: solid 5px #0e0; width: 250px;">
	<div style="height: 50px; width: 50px; background-color: Red; float:left;"></div>
	<div style="height: 100px; width: 100px; background-color: Green; clear:both;">
		11111111111
		11111111111
	</div>
</div>

  对元素清理实际上为前面的浮动元素留出了垂直空间,这样可以解决我们之前的一个问题,看前面的图片的时候我们发现div内的所有元素浮动的话就会不占据文档空间,这样父元素,高度为0,可能很多效果也不见了

  都向左浮动,父元素宽度为0

 <div style="border: solid 5px #0e0; width:300px;">
 	<div style="height: 100px; width: 100px; background-color: Red;  float:left;">
 	</div>
 	<div style="height: 100px; width: 100px; background-color: Green;  float:left;">
 	</div>
 	<div style="height: 100px; width: 100px; background-color: Yellow;  float:left;">
 	</div>
 </div>

  如果我们想让父元素在视觉上包围浮动元素可以向下面这样处理

  在最后添加一个空div,对它清理

<div style="border: solid 5px #0e0; width:300px;">
	<div style="height: 100px; width: 100px; background-color: Red;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Green;  float:left;">
	</div>
	<div style="height: 100px; width: 100px; background-color: Yellow;  float:left;">
	</div>
	<div style="clear:both;"></div>
</div>

  当然这样做有很多缺点,有些javascript也可以做出类似效果,这里不细说,值得注意的是应用值为hidden或auto的overflow属性会有一个副作用:自动清理包含的任何浮动元素,所以说当页面出现相关问题时,可以看看是不是这个属性搞的鬼。

  这样,有了这些基本知识后,我们应用CSS的时候就可以解决很多以前很百思不得其解的问题了。

 

本站原创内容,转载请注明来源:https://www.liutonghui.com/80

深入浅出之Smarty模板引擎工作机制(二)
上一篇 2014-08-18
jQuery实现文章列表指定行后插入广告
下一篇 2014-09-12

评论列表(0条)

  • 暂无评论

发表评论

captcha

相关推荐

  • HTML5 data-* 自定义属性

      在HTML5中添加了data-*的方式来自定义属性,所谓data-*实际上就是data-前缀加上自定义的属性名,使用这样的结构可以进行数据存放。使用data-*可以解决自定义属性混乱无管理的现状。   读写方式   data-*有两种设置方式,可以直接在HTML元素标签上书写 &lt;div id="test" data-age="24"&gt; Click Here &lt;/div&gt;   其中的data-age就是一种自......

    2013-12-12
    16730
  • 深入理解css中position属性及z-index属性

      在网页设计中,position属性的使用是非常重要的。有时如果不能认识清楚这个属性,将会给我们带来很多意想不到的困难。   position属性共有四种不同的定位方法,分别是static、fixed、relative、absolute,sticky。最后将会介绍和position属性密切相关的z-index属性。   第一部分:position:static   static定位是HTML元素的默认值,即没有定位,元素出现在正常的流......

    2017-07-03
    11560
  • 使用 Layui 和 jQuery 实现表单验证

      对于 Layui 表单验证,可以结合 jQuery 使用 Layui 的验证规则。以下是一个示例,展示了如何使用 Layui 和 jQuery 实现用户名、密码、手机号、邮箱、身份证号的表单验证: &lt;!DOCTYPE html&gt; &lt;html lang="en"&gt; &lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;meta name="viewport" con......

    2020-06-14
    21380
  • PHP文字水印,缩略图,图片水印实现类与用法示例

      本文实例讲述了PHP开发的文字水印,缩略图,图片水印实现类与用法。分享给大家供大家参考,具体如下:   1.实现类ImageToTest.class.php参考代码 class ImageToTest { /** * 图片的基本信息 */ private $info; private $image; public function __construct($src){ $info = getima......

    2020-08-22
    19930
  • 华为Mate60手机开售,麒麟5G芯片回归,遥遥领先

      没开发布会,没有预告就直接开卖备受关注的旗舰手机,华为Mate60系列算是开了个头。这几天华为登上了热搜,这次是因为华为Mate60手机携带&ldquo;麒麟芯片&rdquo;提前开售,瞬间售罄,同时也标志着麒麟5G芯片的正式回归。这一消息在各大主流媒体平台上迅速引发热议,网友们纷纷发表意见,自媒体人也争相蹭热度,提出各自观点。   如果你打开华为商城app,可以看到华为已经在自家商城上架了华为Mate60系列手机,而这些手机已经......

    2023-08-31
    11930
  • 刀郎——不被世俗所缚的纯粹歌者

      刀郎宣布停止更新抖音视频,停更的时间可能会是一年或者三年,因为他要再次投入到音乐创作中,这一决定让很多歌迷不舍。在这个功利主义盛行、金钱至上的时代,刀郎选择暂别,专心致力于音乐创作,让人感受到他对音乐的真诚追求。他并不被外界的追逐所左右,而是选择对音乐的尊重,也是对自我的坚守。   在抖音上拥有1800万粉丝的刀郎,在平台上积累了巨大的人气,但他并没有利用这波热度与资本合作,而是选择远离喧嚣,将精力集中在音乐创作上。刀郎从来不做代......

    2023-12-19
    7990
  • Mate70系列一机难求,打破技术封锁,国产科技崛起

      华为Mate70系列自发布以来,供不应求,几乎全网缺货,很难购买到。近日,华为消费者业务BG首席执行官何刚在接受采访时表示,线上线下全平台的预约量已经超过670万台,初期就出现了供货紧张的局面,华为正在要求供应链加班加点生产。   去年的Mate60系列很保守,没有开发布会就直接先锋计划开卖了,而这次Mate70开发布会了,这也表明华为在一些核心技术上实现了突破,具备了更强的自信。何刚表示,Mate70系列的每一颗芯片都具备国产化......

    2024-12-14
    7820
  • 内存涨价?那好,我不买了

      现在内存的价格有多离谱?根据数据统计:自2025年9月以来,DDR5内存价格涨幅超过300%,DDR4内存涨幅150%,就拿256G的DDR5 6400 RECC服务器内存来说,其单条价格已接近6万元,整盒100根总价近600万元。   服务器内存价格先不说,这次内存价格狂涨还波及到了普通消费级市场,以金士顿DDR5 6400 16G x 2为例,其价格从949元,涨到了3879元,简直太离谱了。内存涨价让组装一台电脑的成本大幅增......

    2026-02-03
    5790