Html5之title吸顶功能


Posted in HTML / CSS onJune 04, 2018

吸顶功能

吸顶是一种比较常见的交互效果,当页面滑出屏幕边界,标题会自动吸附在屏幕边缘,用于提示用户。

基本原理

在H5中实现的基本原理就是判断当前页面滑动的距离scrollTop和标题距离页面顶部距离offsetTop的关系,进而设置标题的position = fixed。这里需要明白scrollTop和offsetTop属性的含义。

scrollTop

代表在有滚动条时,滚动条向下滚动的距离也就是元素顶部被遮住部分的高度。在没有滚动条时scrollTop==0恒成立。单位px,可读可设置。

Html5之title吸顶功能

offsetTop

当前元素顶部距离最近父元素顶部的距离,和有没有滚动条没有关系。单位px,只读元素。

Html5之title吸顶功能

所以,当scrollTop>offsetTop时,title的position = fixed,top = 0,使之固定在屏幕上方;当scrollTop < offsetTop,取消position = fixed,代码如下:

if (fixedDom[0].offsetTop - elementScrollTop < 0){
            fixedDom.addClass("road-tab-fixed")
          }else {
            fixedDom.removeClass("road-tab-fixed")
          }

效果如下:

Html5之title吸顶功能

优化

有图看出基本功能实现的差不多了,但是感觉哪里怪怪的。当页面向上滑时效果还是比较自然的,但是当页面下滑时,只有当页面完全滑到顶部时,标题才会回到原位,导致过度不自然,所以对于titile的position的设定要分两种情况:上滑和下滑。

判断上下滑动方向

判断上下滑动点击此处

当页面上滑时

当scrollTop>offsetTop时,title的position = fixed,top = 0,使之固定在屏幕上方;

当页面下滑时

当scrollTop<offsetTop时,取消掉fixed属性,这样就会使标题跟随页面滑动下来,交互更加自然了,

代码如下:

if(beforeElementScrollTop - elementScrollTop <=0){//up
            console.log('up');
            if (beforeOffsetTop - elementScrollTop < 0){
              fixedDom.addClass("road-tab-fixed")
            }
          }else{
            console.log('down');
            // console.log('beforeOffsetTop-----------',beforeOffsetTop);
            // console.log('elementScrollTop--------------',elementScrollTop);
            if (beforeOffsetTop - elementScrollTop >= 0){
              fixedDom.removeClass("road-tab-fixed")
            }
          }

效果如下:

Html5之title吸顶功能

优化之scroll节流

当对页面监听了scroll事件后,滑动时scroll的回调会一直在执行,影响到页面性能,而节流只允许一个函数在 X 毫秒内执行一次,只有当上一次函数执行后过了你规定的时间间隔,才能进行下一次该函数的调用。代码如下

const fixedDom = $("#road-tab"),
          isIos = utils.getMobileType(),
          tabclass = "road-tab-fixed";
        let beforeElementScrollTop = 0;
        let beforeOffsetTop = fixedDom[0].offsetTop;
        //scroll节流
        const throttle = (func,wait,mustRun) => {
          var timeout,
            startTime = new Date();

          return function() {
            var context = this,
              args = arguments,
              curTime = new Date()
            clearTimeout(timeout)
            // 如果达到了规定的触发时间间隔,触发 handler
            if(curTime - startTime >= mustRun){
              beforeElementScrollTop = document.body.scrollTop;
              console.log("beforelementScrollTop----------",document.body.scrollTop);
              func.apply(context,args);
              startTime = curTime
              // 没达到触发间隔,重新设定定时器
            }else{
              timeout = setTimeout(func, wait)
            }
          }
        }
        const winScroll = (e) => {
          const elementScrollTop=document.body.scrollTop;
          console.log('elementScrollTop--------------',elementScrollTop);
          if(beforeElementScrollTop - elementScrollTop <=0){//up
            console.log('up');
            if (beforeOffsetTop - elementScrollTop < 0){
              fixedDom.addClass("road-tab-fixed")
            }
          }else{
            if (beforeOffsetTop - elementScrollTop >= 0){console.log("UUUUUU");
              fixedDom.removeClass("road-tab-fixed")
            }
          }
        };
        $(window).off("scroll").on("scroll", throttle(winScroll,10,100));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
纯CSS3实现图片无间断轮播效果
Aug 25 HTML / CSS
详解CSS3中字体平滑处理和抗锯齿渲染
Mar 29 HTML / CSS
利用css3画个同心圆示例代码
Jul 03 HTML / CSS
CSS3与动画有关的属性transition、animation、transform对比(史上最全版)
Aug 18 HTML / CSS
纯CSS3制作页面切换效果的实例代码
May 30 HTML / CSS
css3进阶之less实现星空动画的示例代码
Sep 10 HTML / CSS
利用HTML5中Geolocation获取地理位置调用Google Map API在Google Map上定位
Jan 23 HTML / CSS
HTML5的语法变化介绍
Aug 13 HTML / CSS
html5 canvas手势解锁源码分享
Jan 07 HTML / CSS
使用layui框架实现点击左侧导航切换右侧内容且右侧选项卡跟随变化的效果
Nov 10 HTML / CSS
使用canvas对video视频某一刻截图功能
Sep 25 HTML / CSS
CSS实现五种常用的2D转换
Dec 06 HTML / CSS
浅谈Html5移动端ios/Android兼容性总结
Jun 01 #HTML / CSS
HTML5中的websocket实现直播功能
May 21 #HTML / CSS
深入浅析HTML5中的article和section的区别
May 15 #HTML / CSS
HTML5触摸事件实现移动端简易进度条的实现方法
May 04 #HTML / CSS
HTML5声音录制/播放功能的实现代码
May 03 #HTML / CSS
HTML5离线应用与客户端存储的实现
May 03 #HTML / CSS
浅谈Html5多线程开发之WebWorkers
May 02 #HTML / CSS
You might like
如何在PHP中使用Oracle数据库(2)
2006/10/09 PHP
php cookie的操作实现代码(登录)
2010/12/29 PHP
深入PHP数据缓存的使用说明
2013/05/10 PHP
php遍历目录输出目录及其下的所有文件示例
2014/01/27 PHP
一个严格的PHP Session会话超时时间设置方法
2014/06/10 PHP
PHP中常用的输出函数总结
2014/09/22 PHP
php约瑟夫问题解决关于处死犯人的算法
2015/03/23 PHP
Yii2框架使用计划任务的方法
2016/05/25 PHP
layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例
2018/05/12 PHP
php查看一个变量的占用内存的实例代码
2020/03/29 PHP
javascripit实现密码强度检测代码分享
2013/12/12 Javascript
JavaScript基础知识学习笔记
2014/12/02 Javascript
jQuery使用append在html元素后同时添加多项内容的方法
2015/03/26 Javascript
js实现继承的5种方式
2015/12/01 Javascript
浅谈javascript中的call、apply、bind
2016/03/06 Javascript
jquery自适应布局的简单实例
2016/05/28 Javascript
JS实现的幻灯片切换显示效果
2016/09/07 Javascript
React如何利用相对于根目录进行引用组件详解
2017/10/09 Javascript
node.js操作MongoDB的实例详解
2017/10/11 Javascript
vue父组件向子组件传递多个数据的实例
2018/03/01 Javascript
JS实现的DOM插入节点操作示例
2018/04/04 Javascript
js实现金山打字通小游戏
2020/07/24 Javascript
python 打印出所有的对象/模块的属性(实例代码)
2016/09/11 Python
解决python "No module named pip" 的问题
2018/10/13 Python
Python异常的检测和处理方法
2018/10/26 Python
浅谈numpy生成数组的零值问题
2018/11/12 Python
python+opencv3.4.0 实现HOG+SVM行人检测的示例代码
2021/01/28 Python
html5 Canvas实现图片旋转的示例
2018/01/15 HTML / CSS
美国网上眼镜商城:Zenni Optical
2016/11/20 全球购物
初三家长会邀请函
2014/01/18 职场文书
影子教师研修方案
2014/06/14 职场文书
汽车服务工程专业自荐信
2014/09/02 职场文书
无犯罪记录证明样本
2015/06/16 职场文书
MySQL获取所有分类的前N条记录
2021/05/07 MySQL
青岛市的收音机研制与生产
2022/04/07 无线电
vue 自定义的组件绑定点击事件
2022/04/21 Vue.js