HTML(WEB)开发day06

作者:gqk;

清除浮动:好比我们的浮动,有浮动开始,则就应该有浮动结束。

为什么要清除浮动?

由于浮动元素不再占用原文档流的位置,所以它会对后面的元素排版产生影响,为了解决这些问题,此时就需要在该元素中清除浮动。

准确地说,并不是清除浮动,而是清除浮动后造成的影响

如果浮动一开始就是一个美丽的错误,那么请用正确的方法挽救它。

清除浮动本质

清除浮动主要为了解决父级元素因为子级浮动引起内部高度为0 的问题

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		div{
			border: 1px solid red;

		}
		.son1{
			height: 100px;
			width: 100px;
			background-color: pink;
			float: left;
		}
		.son2{
			height: 100px;
			width: 100px;
			background-color: yellow;
			float: left;
		}
		.foller{
			width: 400px;
			height: 100px;
			background-color: green;
		}
	</style>
</head>
<body>
	<div class="father">
		<div class="son1">1</div>
		<div class="son2">2</div>
	</div>
	<div class="foller">3</div>
</body>
</html>

  由于 浮动后 原有的位置没有了 所以产生一下的问题,

清除浮动的方法

在CSS中,clear属性用于清除浮动,其基本语法格式如下:

选择器{clear:属性值;}

额外标签法

html 是W3C推荐的做法是通过在浮动元素末尾添加一个空的标签例如 <div style=”clear:both”></div>,或则其他标签br等亦可。

优点: 通俗易懂,书写方便

缺点: 添加许多无意义的标签,结构化较差。 我只能说,w3c你推荐的方法我不接受,你不值得拥有。。

父级添加overflow属性方法

~~~css 可以给父级添加: overflow为 hidden|auto|scroll 都可以实现。 ~~~ 优点: 代码简洁

缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。

使用after伪元素清除浮动

:after 方式为空元素的升级版,好处是不用单独加标签了

使用方法:

```css .clearfix:after { content: ""; display: block; height: 0; clear: both; visibility: hidden; }

.clearfix {zoom: 1;} / IE6、7 专有 */ ```

项目案例: 云道页面

定位(position)

那么定位,最长运用的场景再那里呢? 来看几幅图片,你一定会有感悟

左右箭头压住图片:

如果用标准流或者浮动,实现会比较复杂或者难以实现,此时我们用定位来做,just soso!

元素的定位属性:(先确定定位模式,再去选择偏移量)

元素的定位属性主要包括定位模式和边偏移两部分

偏移量:

top | 顶端偏移量,定义元素相对于其父元素上边线的距离 | | bottom | 底部偏移量,定义元素相对于其父元素下边线的距离 | | left | 左侧偏移量,定义元素相对于其父元素左边线的距离 | | right | 右侧偏移量,定义元素相对于其父元素右边线的距离 |也就说,以后定位要和这边偏移搭配使用了, 比如 top: 100px; left: 30px; 等等

1、定位模式(定位的分类)

在CSS中,position属性用于定义元素的定位模式,其基本语法格式如下:

选择器{position:属性值;}

position属性的常用值

2,静态定位static:默认的定位方式

3,相对定位:relative:相对定位是将元素相对于它在标准流中的位置进行定位,当position属性的取值为relative时,可以将元素定位于相对位置。

以自己为基准进行偏移。

对元素设置相对定位后,可以通过边偏移属性改变元素的位置,但是它在文档流中的位置仍然保留。如下图所示,即是一个相对定位的效果展示:

注意:

  1. 相对定位最重要的一点是,它可以通过边偏移移动位置,但是原来的所占的位置,继续占有。
  2. 其次,每次移动的位置,是以自己的左上角为基点移动(相对于自己来移动位置)
  3. 不会脱标(定位后仍然在标准流里面)

4,绝对定位:absoult=========position:absoult 注意:定位最重要的一点是,它可以通过边偏移移动位置,但是它完全脱标,完全不占位置。

父级没有定位:会按照浏览器的窗口进行定位

父级有定位

绝对定位是将元素依据最近的已经定位(绝对、固定或相对定位)的父元素(祖先)进行定位。

 总结:

子绝父相:这句话的意思是 子级是绝对定位的话, 父级要用相对定位

 因为子盒子需要在 父亲的位置随意移动所以必须用绝对定位而且不占有位置,而父亲刚好相反,他本身占有位置,所以子绝对定位父亲相对定位

绝对定位的盒子水平/垂直居中

普通的盒子是左右margin 改为 auto就可, 但是对于绝对定位就无效了

定位的盒子也可以水平或者垂直居中,有一个算法。

  1. 首先left 50% 父盒子的一半大小

  2. 然后走自己外边距负的一半值就可以了 margin-left。

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		.father{
			height: 300px;
			width: 300px;
			border:5px solid red;
			position: absolute;
			left: 50%;
			margin-left: -150px;
			top: 25%;
		}	
	</style>
</head>
<body>
	<div class="father">		
	</div>
</body>
</html>

  

5,固定定位:fixed(我帅 我说了算)(烦人的小广告)

当对元素设置固定定位后,它将脱离标准文档流的控制,始终依据浏览器窗口来定义自己的显示位置。不管浏览器滚动条如何滚动也不管浏览器窗口的大小如何变化,该元素都会始终显示在浏览器窗口的固定位置。

固定定位有两点:

  1. 固定定位的元素跟父亲没有任何关系,只认浏览器。
  2. 固定定位完全脱标,不占有位置,不随着滚动条滚动.

ie6等低版本浏览器不支持固定定位。

 

posted @ 2018-08-07 15:22  少侠gqk  阅读(190)  评论(0编辑  收藏  举报