移动端手指操控左右滑动的菜单

本文实例为大家分享了移动端手指操控左右滑动菜单的具体代码,供大家参考,具体内容如下

<!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\" style=\"display: block;\">
 <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\" style=\"display: none;\">
 <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> 

移动端手指操控左右滑动的菜单

移动端手指操控左右滑动的菜单

移动端手指操控左右滑动的菜单

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

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容