1,绝对定位问题

1,绝对定位元素特性

  1. display 默认block。所以行内元素设置绝对定位后可直接设置宽高
  2. 脱离文档流,所以 margin: auto 失效
  3. 绝对定位元素相对于最近的非 static 祖先元素定位。当这样的祖先元素存在时,则相对于 ICB(initial containing block,初始包含块)。

2,初始包含问题

如果参考系是初始包含块,则

设置 top 时,参考点是页面顶部,而不是浏览器首屏顶部

设置 bottom 时,参考点浏览器首屏的底部,而不是页面底部

所以有这么一道经典面试题大家品一下:

在这里插入图片描述

2,粘性定位

一句话总结可以认为是相对定位和固定定位的混合,定位元素滚动到某个阈值之前表现为相对定位,之后表现为固定定位。

先看下实际应用

在这里插入图片描述

实现起来也比较简单,只需要粘性定位元素一个 top即可。当定位元素距离浏览器视口顶部到达 top 值后,就表现为固定定位。

举例:

<head>
  <style>
    * {
      margin: 0;
      padding: 0;
    }
    .header {
      height: 200px;
      background-color: seagreen;
    }
    .sticky {
      position: sticky;
      top: 20px;
      width: 50px;
      height: 50px;
      background-color: salmon;
    }
    .content {
      height: 800px;
      background-image: linear-gradient(#e66465, #9198e5);
    }
  </style>
</head>
<body>
  <div class="header">顶部其他元素</div>
  <div class="sticky"></div>
  <div class="content"></div>
</body>

在这里插入图片描述

注意点:

  1. 至少得指定 top, right, bottom,left 其中之一,才可使粘性定位生效。否则其行为与相对定位相同
  2. 和其他定位一样,top 优先级大于 bottomleft 优先级大于 right
  3. 粘性定位元素的包含块,设置 overflow: hidden; 会使粘性定位失效

以上面的例子来说,下面的写法就会使粘性定位失效

<head>
  <style>
    .box {
      position: relative;
      overflow: hidden;
    }
  </style>
</head>
<body>
  <div class="box">
    <div class="header">顶部其他元素</div>
    <div class="sticky">one</div>
    <div class="content"></div>
  </div>
</body>

以上。

原文地址:https://blog.csdn.net/qq_40147756/article/details/134747939

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_36008.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注