zoukankan      html  css  js  c++  java
  • 移动端手指操控左右滑动的菜单

    <!DOCTYPE html>    
    <html lang="en">    
    <head>    
        <meta charset="UTF-8">    
        <title>移动端手指操控左右滑动的菜单</title>  
        <style type="text/css">  
        body {margin:0;}
        .menu-wrap {
        	 100%;
        	height: 50px;
        	overflow: hidden;
        }
        .menu-wrap-layer2 {
        	 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;
        	 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>  














  • 相关阅读:
    JVM,反射与动态代理
    11款实用的一句话网站设计代码
    Winform TextBox中只能输入数字的几种常用方法(C#)
    列表checkbox全选
    函数调用约定
    vs编译后在本机能运行,在别的机器上运行提示runtime Error的问题
    学习地形编程(一)
    Ogre中动态三维鼠标的实现
    讲讲volatile的作用
    绕任意轴旋转的推导
  • 原文地址:https://www.cnblogs.com/xutongbao/p/9924927.html
Copyright © 2011-2022 走看看