模仿头条导航的左右滚动效果
<!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>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?