温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

HTML如何实现移动端手指操控左右滑动的菜单

发布时间:2021-06-29 15:24:09 来源:亿速云 阅读:266 作者:小新 栏目:web开发

这篇文章主要介绍HTML如何实现移动端手指操控左右滑动的菜单,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

具体内容如下

<!DOCTYPE html>   <html lang="en">   <head>     <meta charset="UTF-8">     <title>移动端手指操控左右滑动的菜单</title>    <style type="text/css">    body {margin:0;}   .menu-wrap {    width: 100%;    height: 50px;    overflow: hidden;   }   .menu-wrap-layer2 {    width: 100%;    height: 50px;    overflow: hidden;   }   .menu-list {    display: inline-block;    white-space: nowrap;    transition-duration: 0ms;    transform: translateX(0px);   }   .menu-list-item {    display: inline-block;   }   .menu-list-item span {    display: inline-block;    width: 100px;    margin: 0 3px;    text-align: center;   }   </style>   </head>   <body>  <div id="menu-wrap" class="menu-wrap">  <div class="menu-list js-menu-list">    <div class="menu-list-item">      <span data-index="0">全站</span>        </div>   <div class="menu-list-item">      <span data-index="1">动画</span>    </div>    <div class="menu-list-item">      <span data-index="2">番剧</span>    </div>   <div class="menu-list-item">      <span data-index="3">国创</span>    </div>    <div class="menu-list-item">      <span data-index="4">音乐</span>    </div>   <div class="menu-list-item">      <span>舞蹈</span>    </div>    <div class="menu-list-item">      <span>科技</span>    </div>   <div class="menu-list-item">      <span>游戏</span>    </div>    <div class="menu-list-item">      <span>娱乐</span>    </div>   <div class="menu-list-item">      <span>电影</span>    </div>    <div class="menu-list-item">      <span>电视剧</span>    </div>   <div class="menu-list-item">      <span>纪录片</span>    </div>     </div>  </div> <div> <div class="menu-wrap-layer2 js-menu-wrap-layer2 js-menu-wrap0" >  <div class="menu-list js-menu-list">    <div class="menu-list-item">      <span>二级菜单1</span>    </div>   <div class="menu-list-item">      <span>二级菜单2</span>    </div>    <div class="menu-list-item">      <span>二级菜单3</span>    </div>   <div class="menu-list-item">      <span>二级菜单4</span>    </div>    <div class="menu-list-item">      <span>二级菜单5</span>    </div>   <div class="menu-list-item">      <span>二级菜单6</span>    </div>    <div class="menu-list-item">      <span>二级菜单7</span>    </div>   <div class="menu-list-item">      <span>二级菜单8</span>    </div>    <div class="menu-list-item">      <span>二级菜单9</span>    </div>   <div class="menu-list-item">      <span>二级菜单10</span>    </div>    <div class="menu-list-item">      <span>二级菜单11</span>    </div>   <div class="menu-list-item">      <span>二级菜单12</span>    </div>     </div>  </div>    <div class="menu-wrap-layer2 js-menu-wrap-layer2 js-menu-wrap1" >  <div class="menu-list js-menu-list">    <div class="menu-list-item">      <span>二级菜单s1</span>    </div>   <div class="menu-list-item">      <span>二级菜单s2</span>    </div>     </div>  </div> </div>     <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script> <script type="text/javascript">     $(function() {  var menu = function(wrap, menuList, menuItems) {  var deviceWidth = $(window).width();  var positionX = 0;  var menuListPositionX1 = wrap.offset().left;   var menuListPositionX2 = menuListPositionX1 + wrap.width();       $(menuList).attr("style","transition-duration: 0ms;transform: translateX(0px);");    menuList.addEventListener('touchstart',function(event){   if(event.targetTouches.length == 1){      var touch = event.targetTouches[0];      positionX = touch.pageX;      //确定本次拖动transform的初始值      var transformStr = menuList.style.transform;      transformStr = transformStr.substring(11);      var index = transformStr.lastIndexOf("p");      transformStr = transformStr.substring(0, index);      transformX = parseInt(transformStr);      //确定本次拖动的div宽度值      var widthStr = menuList.style.width;      thisWidth = parseInt(widthStr.substring(0,widthStr.lastIndexOf("p")));    }  }, false);  menuList.addEventListener('touchmove', function(event) {    //阻止其他事件    event.preventDefault();    //获取当前坐标    if(event.targetTouches.length == 1){      var touch = event.targetTouches[0];      menuList.style.transform = 'translateX('+(transformX+touch.pageX-positionX)+'px)';      $(menuList).css("width",thisWidth+positionX-touch.pageX);    }  }, false);  menuList.addEventListener('touchend', function(event) {    var menuItem1 = menuItems[0];    var menuItem1Left = $(menuItem1).offset().left;    var menuItem2 = menuItems[menuItems.length-1];    var menuItemPositionX = $(menuItem2).offset().left+$(menuItem2).width();    var firstToLast = menuItemPositionX - menuItem1Left;    if (menuItem1Left > menuListPositionX1 || firstToLast < deviceWidth) {      menuList.style.transform = 'translateX('+(menuListPositionX1)+'px)';    }    if(menuItemPositionX < menuListPositionX2 && menuItem1Left < 0 && firstToLast > deviceWidth) {     var myWidth = $(menuList).width() - deviceWidth;      menuList.style.transform = 'translateX('+(0-myWidth)+'px)';    }  }, false);  }    var event = function() {  $('#menu-wrap .js-menu-list span').click(function () {   console.log($(this).attr('data-index'));   var activeMenu = $('.js-menu-wrap' + $(this).attr('data-index'));   activeMenu.siblings().hide();   activeMenu.show();  });  }  var init = function() {  var menuWrap = $('#menu-wrap');  var menuList = $("#menu-wrap .js-menu-list")[0];  var menuListItems = $("#menu-wrap .menu-list-item");  menu(menuWrap, menuList, menuListItems);    var menuWrapLayer2 = $('.js-menu-wrap-layer2');  var helper = function (tempWrap, tempMenuList, tempMenuListItems) {    var tempFun = function() {   menu(tempWrap, tempMenuList, tempMenuListItems);   }();  }   for (var i = 0; i < menuWrapLayer2.length; i++) {   var tempWrap = $(menuWrapLayer2[i]);   var tempMenuList = $(menuWrapLayer2[i]).find('.js-menu-list')[0];   var tempMenuListItems = $(menuWrapLayer2[i]).find('.menu-list-item');   helper(tempWrap, tempMenuList, tempMenuListItems);  }  event();  }(); }); </script> </body>   </html>

HTML如何实现移动端手指操控左右滑动的菜单

HTML如何实现移动端手指操控左右滑动的菜单

HTML如何实现移动端手指操控左右滑动的菜单

以上是“HTML如何实现移动端手指操控左右滑动的菜单”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI