粘性定位是不是css3新增的

今天小编给大家分享一下粘性定位是不是css3新增的的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

创新互联于2013年创立,先为思礼等服务建站,思礼等地企业,进行企业商务咨询服务。为思礼企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

粘性定位是css3新增的,粘性定位指的是position定位属性值设置为sticky,表示基于用户的滚动位置来定位,元素定位表现为在跨越特定阈值前为相对定位,之后是固定定位,语法为“元素{position: sticky;}”。

本教程操作环境:windows10系统、CSS3&&HTML5版本、Dell G3电脑。

粘性定位是css3新增的吗

CSS3粘性定位position sticky
一、介绍

css3中新的定位属性,本身也具有定位元素的属性

理解为相对定位position:relative + 固定定位position:fixed的混合体

position:sticky粘性定位,基于用户的滚动定位

sticky 英文字面意思是粘,粘贴,所以可以把它称之为粘性定位。

position: sticky; 基于用户的滚动位置来定位。

粘性定位的元素是依赖于用户的滚动,在 position:relative 与 position:fixed 定位之间切换。

它的行为就像 position:relative; 而当页面滚动超出目标区域时,它的表现就像 position:fixed;,它会固定在目标位置。

元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。

这个特定阈值指的是 top, right, bottom 或 left 之一,换言之,指定 top, right, bottom 或 left 四个阈值其中之一,才可使粘性定位生效。否则其行为与相对定位相同。

二、基本原理

依赖用户的滚动定位,行为像position:relative,当页面滚动超出目标区域,行为表现为position:fixed

什么是目标区域

相对父元素,超出阈值,这个阈值通过top、left、right、bottom确定

滚动元素

overflow不是visible的元素

流动盒子

粘性定位元素最近的可滚动元素的尺寸盒子。如果没有滚动盒子,则是浏览器视窗盒子

粘性约束矩形

粘性布局元素的父级元素矩形

三、生效的条件

①父元素不能是overflow:hidden/overflow:auto/overflow:scroll/overflow:overlay

②父元素高度不能低于sticky高度,否则无法显示效果

③必须指定top/left/right/bottom任一个方向的属性值

④作用域在父元素内,效果在父元素内生效

⑤在可视范围内为relative,反之是fixed

⑥同一个容器内多个粘性元素彼此独立偏移,可能会发生重叠

四、举例子
(1)语法
p sticky{
	position:-webkit-sticky;/*safair*/
	position:sticky;
	top:0;
}
(2)一个sticky元素

    
    
    
    

        

    

效果展示

粉色背景的盒子是上述的流盒,蓝色为粘性约束的矩形框(父元素p),紫色的为粘性元素(p父里面的nav子)

粘性定位是不是css3新增的

向上滚动鼠标,当距离top:20px的时候导航栏固定,但不超过紫色的父亲p

粘性定位是不是css3新增的

向上滚动鼠标,父亲p紫色盒子粘性约束矩形超出流盒子,导航栏蓝色盒子也向上滚动了,但是始终在紫色盒子父p里面
粘性定位是不是css3新增的

向上滚动鼠标,紫色的盒子超出粉色流盒子,消失在可视范围内

粘性定位是不是css3新增的

(3)多个sticky元素

    
    
    
    

        

        
头部
    

效果展示

粉色背景的盒子是上述的流盒,蓝色为粘性约束的矩形框(父元素p),紫色的为粘性元素(p父里面的nav子),橙色的也为粘性元素(p里面的header子)

粘性定位是不是css3新增的

向上滚动鼠标,蓝色的导航栏固定,橙色的向上滚动,蓝色和橙色两个粘性元素的粘性约束矩形都在紫色p父里面
粘性定位是不是css3新增的

向上滚动鼠标,蓝色的导航栏消失,橙色的盒子固定,覆盖导航栏(证明后面的粘性元素会覆盖前面的粘性元素)

粘性定位是不是css3新增的

向上滚动鼠标,橙色的盒子超出粉色流盒子,消失在可视范围内

粘性定位是不是css3新增的

总结:当有多个粘性元素的时候,后面的粘性元素会覆盖前面的粘性元素

(4)加上z-index

前文总结了z-index的层级覆盖,来试试加上z-index会发生怎么样的覆盖效果

nav.z-index: 20 header.z-index:19

复习:css中的z-index层级问题


    
    
    
    

        

        
头部
    

效果展示

粘性定位是不是css3新增的

蓝色的导航栏逐渐覆盖黄色的头部

粘性定位是不是css3新增的

粘性定位是不是css3新增的

粘性定位是不是css3新增的

总结:粘性元素生效相当于position:fixed,z-index会生效

以上就是“粘性定位是不是css3新增的”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注创新互联行业资讯频道。


分享文章:粘性定位是不是css3新增的
标题链接:http://azwzsj.com/article/pgdceo.html