webapp手机网站顶部固定fixed不为0的情况出现,滑动出现闪动!

问题描述

头部是一个普通的div,高度是48,头部下面有个固定的banner,手下滑的时候,banner会固定在浏览器最顶部不动。出现的问题是,PC端是好的,手机浏览器向上滑动的时候出现闪动!影响用户体验。

之前的做法

javascript 复制代码
 if ($(window).scrollTop() < 48) {
                $(".nav ").css("top", 48 - parseInt($(window).scrollTop()));
            }else{
              $(".nav ").css("top", "0");  
            }
        $(window).scroll(function () {
            $(".nav ").css("top", "0");
            var toplength = parseInt($(window).scrollTop());
            if ($(window).scrollTop() < 48) {
                $(".nav ").css("top", 48 - toplength);
            }
 });

这样做手机网站中会出现明显的闪动效果!

改进之后的做法

javascript 复制代码
if ($(window).scrollTop() < 48) {
            $(".nav ").stop().animate({"top":48 - parseInt($(window).scrollTop())},"fast");
        } else {
            $(".nav ").stop().animate({"top": "0"},"fast");
        }
$(window).scroll(function () {
            var toplength = parseInt($(window).scrollTop());
            if ($(window).scrollTop() < 48) {
                $(".nav ").stop().animate({"top": 48 - toplength},"fast");
            }else{
            $(".nav ").stop().animate({"top": "0"},"fast"); 
            }
});

这样做滑动的时候,有个向上的动画效果,不会出现闪动!

方法二

思路:顶部固定的地方,一开始和上面不固定的地方是一体的,不写position:fixed,当要固定的div的offset比scrolltop小的时候,让其固定。(我之前之所以没有用这个方法,是因为整个页面在ios中要引用,当在ios中的时候,头部不出现。)

代码如下:

javascript 复制代码
menuPosition: function() {
            var m = $(window).scrollTop(), 
            n = $("#idmenuinfo的父亲").offset().top,
            l = $("#menuinfo");
            if (m >= n) {
                if (!l.hasClass("menuinfo")) {
                    l.addClass("menuinfo")
                }
            } else {
                l.removeClass("menuinfo")
            }
        }

menuinfo的样式如下:

css 复制代码
.menuinfo {
  position: fixed!important;
  width: 100%;
  left: 0;
  top: 0;
}

期待更好的解决方案!

相关推荐
辻戋24 分钟前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保26 分钟前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun1 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp1 小时前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.2 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl4 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫6 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友6 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理8 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻8 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js