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封闭ios(Html5 页面适配iPhoneX就是那么简单)
- html53d效果代码(HTML5 直播疯狂点赞动画实现代码 附源码)
- HTML5离线缓存
- html5隐藏数字(HTML5去掉输入框type为number时的上下箭头的实现方法)
- 只用html5简单动画代码(HTML5 3D书本翻页动画的实现示例)
- HTML5 <abbr>标签
- html5移动app开发实战(html5启动原生APP总结)
- html5带放大镜的搜索代码(html5借用repeating-linear-gradient实现一把刻度尺ruler)
- html5怎么将字体变为红色(Html5自定义字体解决方法)
- html5怎么滚动屏幕(HTML5 video进入全屏和退出全屏的实现方法)
- html5播放器按菜单键没反应(解决HTML5中的audio在手机端和微信端的不能自动播放问题)
- html5表单元素自带验证功能(纯CSS3实现表单验证效果非常不错)
- html5怎么设置倾斜(HTML5 body设置自适应全屏)
- html5页面强制刷新(移动端html5判断是否滚动到底部并且下拉加载)
- html5自定义结构指令(浅析HTML5 meta viewport参数)
- 《乡村爱情13》开播,新版刘能以假乱真,编剧思维进入瓶颈(新版刘能以假乱真)
- 当年的 白洋淀战神 练肌肉 嘎子哥也成为行走的荷尔蒙(当年的白洋淀战神)
- 肌肉小子陈康, 亚洲巨兽 黄哲勋,哪个才是你的菜(肌肉小子陈康亚洲巨兽)
- 新闻周刊 青岛网红 赵厂长 编段子一箩筐输出快乐,陪父亲十二载勇斗病魔(新闻周刊青岛网红)
- 44岁夏雨演谋女郎爸,大其24岁却看不出,互动不怕袁泉吃醋(44岁夏雨演谋女郎爸)
- 全椒人,你还记得吗 那年,那人,那网,那些我们的青春记忆(全椒人你还记得吗)
热门推荐
- border和background区别(css中background-origin属性的使用解析)
- C#类的访问修饰符
- laravel5.7项目实战(基于Laravel 5.2 regex验证的正确写法)
- phpstudy使用教程最新版(phpstudy安装使用图文教程)
- python 正则表达式在代码里的使用(python中正则表达式与模式匹配)
- docker-compose怎么编写(docker-compose部署php项目实例详解)
- idea社区版使用tomcat部署项目(基于IDEA部署Tomcat服务器的步骤详解)
- 防火墙如何设置ftp连接(浅谈防火墙对FTP的影响及故障排除分析)
- vue十大基础知识(vue实战中的一些实用小魔法汇总)
- dockernginx怎么设置容器(docker nginx + https 子域名配置详细教程)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9