模仿头条导航的左右滚动效果

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
    <title></title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    <style>
        .scroll{
            width:2000px;
            height:100px;
            display: flex;
            flex-direction: row;
            border:1px solid gray;
            position: fixed;
            top: 0;
            left:0;
        }
        .flex-item{
            flex: 14;
            border-right: 1px solid gray;
            line-height: 100px;
            text-align: center;
        }
    </style>
</head>
<body>
 
<div class="scroll">
    <div class="flex-item">推荐</div>
    <div class="flex-item">热点</div>
    <div class="flex-item">视频</div>
    <div class="flex-item">济南</div>
    <div class="flex-item">社会</div>
    <div class="flex-item">头条</div>
    <div class="flex-item">问答</div>
    <div class="flex-item">图片</div>
    <div class="flex-item">娱乐</div>
    <div class="flex-item">科技</div>
    <div class="flex-item">汽车</div>
    <div class="flex-item">体育</div>
    <div class="flex-item">财经</div>
    <div class="flex-item">军事</div>
</div>
 
<script>
    var startX=0;
    var startY=0;
    var enX=0;
    var screenWidth=$(window).width();
    var elementWidth=$(".scroll").width();
    var lei=0;
    var flag=false;
    var flag1=false;
 
    var leijia=0;
    $('body').bind('touchstart',function(e){
        startX = e.originalEvent.changedTouches[0].pageX,
                startY = e.originalEvent.changedTouches[0].pageY;
 
    });
    $('body').bind('touchend',function(e){
        enX = e.originalEvent.changedTouches[0].pageX
            console.log("离开屏幕*********"+enX)
        lei=enX-startX;
        leijia=leijia+lei;
 
    });
    $('body').bind('touchmove',function(e){
        //获取滑动屏幕时的X,Y
 
        endX = e.originalEvent.changedTouches[0].pageX,
                endY = e.originalEvent.changedTouches[0].pageY;
        //获取滑动距离
        distanceX = endX-startX;
        distanceY = endY-startY;
        //判断滑动方向
        if(Math.abs(distanceX)>Math.abs(distanceY) && distanceX>0){
            console.log('往右滑动');
            if(flag){
                leijia=-(elementWidth-screenWidth);
                flag=false;
            }
            var offsetop=$(".scroll").offset().left;
            if(offsetop<0){
                $(".scroll").css({'left':leijia+distanceX});
            }else{
                $(".scroll").css({'left':0});
                leijia=0;
                flag1=true;
            }
        }else if(Math.abs(distanceX)>Math.abs(distanceY) && distanceX<0){
            console.log('往左滑动'+"*********"+leijia);
            if(flag1){
                leijia=0;
                flag1=false;
            }
            var offsetop=$(".scroll").offset().left;
            if(offsetop>-(elementWidth-screenWidth)){
                $(".scroll").css({'left':leijia+distanceX});
            }else{
                $(".scroll").css({'left':-(elementWidth-screenWidth)});
                leijia=-(elementWidth-screenWidth);
                flag=true;
            }
            console.log("offsetTop********************"+$(".scroll").offset().left)
        }else if(Math.abs(distanceX)<Math.abs(distanceY) && distanceY<0){
            console.log('往上滑动');
        }else if(Math.abs(distanceX)<Math.abs(distanceY) && distanceY>0){
            console.log('往下滑动');
        }else{
            console.log('点击未滑动');
        }
 
    });
     
</script>
</body>
</html>
复制代码

 

posted @   expworld  阅读(231)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示