html5 布局设计(Html5导航栏吸顶方案原理与对比实现)
html5 布局设计
Html5导航栏吸顶方案原理与对比实现一. 什么是吸顶?
吸顶效果是web开发中一种常见的交互方式,常见的应用场景有导航、搜索框等等。能够做流量的横向分发,瞩目的吸顶效果和横滑切tab的手势,能够让用户快速发现更多商品。
市场上享有H5导航栏吸顶效果展示
1.淘宝聚划算吸顶演示:
2.淘宝百亿补贴吸顶演示:
二. 常见的tabbar吸顶方案
- 基于position粘性定位的吸顶方案
- 基于JS监听scroll事件的吸顶方案
三. 方案的原理与对比
1. position粘性方案的实现与详解
1.1. 知识详解
position使我们经常使用的CSS属性,能够在布局和解决一些特定问题时候带来很好的解决方案,例如,卡片的各种icon和标。position粘性定位也是实现吸顶的方案之一,先看看position具有哪些属性值及相关的含义:
取值
相关解释
static
该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时 top, right, bottom, left 和 z-index 属性无效。
relative
该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。position:relative 对 table-*-group, table-row, table-column, table-cell, table-caption 元素无效。
absolute
元素会被移出正常文档流,并不为元素预留空间,通过指定元素相对于最近的非 static 定位祖先元素的偏移,来确定元素位置。绝对定位的元素可以设置外边距(margins),且不会与其他边距合并。
fixed
元素会被移出正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口(viewport)的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。打印时,元素会出现在的每页的固定位置。fixed 属性会创建新的层叠上下文。当元素祖先的 transform, perspective 或 filter 属性非 none 时,容器由视口改为该祖先。
sticky
元素根据正常文档流进行定位,然后相对它的最近滚动祖先(nearest scrolling ancestor)和 containing block (最近块级祖先 nearest block-level ancestor),包括table-related元素,基于top, right, bottom, 和 left的值进行偏移。偏移值不会影响任何其他元素的位置。
MDN传送门
关于sticky属性,顾名思义,单词sticky的中文意思是“粘性的”,其效果是position:relative和position:fixed的结合。当元素在屏幕内,表现为relative,就要滚出显示器屏幕的时候,表现为fixed。这个属性曾经被chrome放弃过,不过后来又得到了支持
<!--示例用法--> nav{ position: -webkit-sticky; position: sticky; top: 0; }
1.2 兼容性
如上图所示,position的sticky已经被各类游览器支持,并且得到了比较好的支持,除safari还需-webkit-前缀支持外。
demo实现:
*{ padding:0; margin:0; } .container{ width:100%; background:rgba(0,0,0,.5); } .nav{ width:100%; height:50px; text-align: center; line-height: 50px; background: black; color:white; position: sticky; top:0; } .body{ width:100%; height:10000px; }
<li class="container"> <li style="width:100%;height:100px;"></li> <li class="nav">position sticky 粘性定位</li> <li class="body"></li> </li>
1.3. 可能会踩得坑
- 使用position:sticky同时,必须同时使用(top、left、right、bottom)中之一,否者无效
- 父元素不能overflow:hidden或者overflow:auto属性,否者无效
- 父元素的高度不能小于sticky元素的高度,否者无效
- sticky元素仅在其父元素内生效
2. JS监听scroll事件的吸顶方案
知识详解 整体思路是通过js对滚动事件的监听,当滚动到顶部时(距顶部的距离为0时),动态的将元素的position属性更改为fixed,进行固定定位达到吸顶的效果。 判断距离顶部的距离比较常规的是使用offsetTop,但offsetTop是相对定位父级的偏移量,倘若需要滚动吸顶的元素出现定位父级元素,那么 offsetTop 获取的就不是元素距离页面顶部的距离。这里我们考虑使用 getBoundingClientRect() 获取页面中某个元素相对浏览器视窗上下左右的距离。 MDN传送门
function compute(){ let ele = document.getElementById('nav'); if(ele.getBoundingClientRect().top === 1){ ele.style.position = "sticky"; ele.style.top = 0; } } window.addEventListener('scroll', compute);
到此这篇关于Html5导航栏吸顶方案原理与对比实现的文章就介绍到这了,更多相关Html5 导航栏吸顶内容请搜索开心学习网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持开心学习网!
- Html5新增的标签
- html5 设置缓存(HTML5实现应用程序缓存Application Cache)
- html5按钮点击跳转(HTML5页面嵌入小程序没有返回按钮及返回页面空白的问题)
- html5本地存储功能(利用Node实现HTML5离线存储的方法)
- html5游戏新手引导开发(使用数据结构给女朋友写个Html5走迷宫游戏)
- HTML5<q> 与 <blockquote> 的区别
- html5如何设置标签(HTML5中在title标题标签里设置小图标的方法)
- h5打开小程序点允许(html5跳转小程序wx-open-launch-weapp踩坑)
- html5实现上传图片预览
- html5最好用语义元素(HTML5语义化元素你真的用对了吗)
- html5自动静音(html5录音功能实战示例)
- html5底部组件(HTML5 Blob对象的具体使用)
- html5基本结构图(HTML5中的网络存储实现方式)
- html5支持video的视频格式(解决html5中的video标签ios系统中无法播放使用的问题)
- html5页面传值表(html5的pushstate以及监听浏览器返回事件的实现)
- html5 data属性
- 今日菜价 芥兰涨幅最高 1.33 ,花菜降幅最高 3.10(今日菜价芥兰涨幅最高)
- 今日菜价 椰菜涨幅最高 3.25 ,水空心菜降幅最高 2.58(今日菜价椰菜涨幅最高)
- 今日菜价 红三鱼涨幅最高 4.41 ,黄鳝降幅最高 5.06(红三鱼涨幅最高)
- 今日菜价 西生菜涨幅最高 6.19 ,生菜降幅最高 5.38(西生菜涨幅最高)
- 今日菜价 青豆角涨幅最高 0.70 ,菜心降幅最高 5.55(青豆角涨幅最高)
- 农村植物,龙芽草若长在您家路旁,请珍惜,它对抗癌有特效(龙芽草若长在您家路旁)
热门推荐
- hive数值转字符串(hive中将string数据转为bigint的操作)
- 阿里云ecs服务器数据在哪儿(阿里云ECS云服务器linux系统安装mysql后远程连接不了踩坑)
- C#中Dispose、析构函数、close的区别
- css基础选择器的语法格式(css -webkit-line-clamp WebKit的CSS扩展WebKit是私有属性)
- html5页面强制刷新(移动端html5判断是否滚动到底部并且下拉加载)
- python解析excel例子(Python玩转Excel的读写改实例)
- mongodb基本数据类型
- dedecms权限调整(增加dedecms后台留言管理功能)
- docker镜像怎么用(Docker和镜像的操作方法)
- 远程给docker容器执行命令(Docker命令让普通用户能够执行的实现)