WEb开发之H5+CSS篇

WEb开发之H5+CSS篇

为什么使用定位

浮动可以让多个块级盒子一行没有缝隙排列显示,经常用于横向排列盒子。

定位则是可以让盒子自由的在某个盒子内移动位置或者固定在屏幕的某个位置,并且可以压住其他盒子。

定位的分类

定位 = 定位模式 + 边偏移

定位模式( position )

static 静态定位

relative 相对定位

absolute 绝对定位

fixed 固定定位

sticky 粘性定位

边偏移 (定位的盒子移动到最终位置)定义元素相对于其父级元素上边线的距离。

top

bottom

left

right

定位各自特点

static 默认定位方式,无定位的意思。

  • 静态定位按照标准流特性摆放位置,它没有边偏移。
  • 静态定位在布局中很少用到。

relative 元素在移动位置的时候,是相对于它原来的位置来说的。

  • 相对于自已原来的位置来移动
  • 原来在标准流的位置继续占有,后面的盒子仍然以标准流的方式对待它。

absolute 元素在移动位置的时候,是相对于它的祖先元素来说的。

  • 如果没有祖先元素或者祖先元素没有定位,则以浏览器为准定位(Document文档)
  • 如果祖先元素有定位(相对,绝对,固定),则以最近一级的有定位祖先元素为参考点移动位置。
  • 绝对定位不在占有原先的位置。(脱标)

fixed 元素固定于浏览器可视区位置。可以在浏览器页面滚动时元素的位置不会改变。

  • 以浏览器的可视窗口为参照点移动元素。

  • 跟父元素没有任何关系。

  • 不随滚动条滚动。

  • 固定定位不占有原先的位置,脱标,是一种特殊的绝对定位。

    技巧:固定在版芯右侧位置。

    ​ 算法:

    ​ 让固定盒子left:50%,走到浏览器可视区的一半位置。

    ​ 让固定定位的盒子margin-left:版芯宽度的一半距离。

sticky 相对定位和固定定位的混合。

  • 以浏览器的可视窗口为参照点移动元素。
  • 占有原先位置。
  • 必须添加top,left,right,bottom其中一个才有效。

为什么使用子绝父相布局

子级绝对定位,不会占有位置,可以放到父盒子里面的任何一个地方,不会影响其他的兄弟盒子。

父级相对定位,限制子盒子在父盒子内显示。

定位叠放次序

z-index 控制盒子的前后次序(z轴)

  • 数值可以是正整数,负整数或0,默认是auto,数值越大,盒子越靠上。
  • 如果属性值相同,则按照书写顺序,后来居上。
  • 数字后面不能加单位,只有定位的盒子才有这个属性。

定位的特殊性

和浮动类似

  1. 行内元素添加绝对或者固定定位,可以直接设置高度和宽度。
  2. 块级元素添加绝对或者固定定位,如果不给宽度或者高度,默认大小是内容的大小。
  3. 脱标的盒子不会触发外边距塌陷。(外边距合并问题不会触发)。
  4. 绝对定位和固定定位会完全压住盒子。
  5. 浮动元素不同,只会压住它下面标准流的盒子,但是不会压住下面标准流盒子里面的文字(图片)。《文字环绕》
  6. 但是绝对定位(固定定位)会压住下面标准流所有的内容。

显示隐藏的2种方式以及区别

  1. display显示隐藏

    none 隐藏元素后,不占有位置。

    block 除了转化为块级元素之外,同时还有显示元素的意思。

  2. visibility显示隐藏

    visible 元素可视

    hidden 元素隐藏,继续占有原来位置。

  3. overflow溢出显示隐藏

    visible 默认,文字超出边框依然显示。

    auto 溢出显示滚动条,不溢出不显示滚动条。

    hidden 隐藏内容,并没有删除。

    scroll 总是显示滚动条。

爱你
每日一句
生活的道路一旦选定,就要勇敢地走到底,决不回头。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全栈工程师MrL

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值