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

<!DOCTYPE html>
<html lang="en">
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<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>

原文地址:https://www.cnblogs.com/gopark/p/9056639.html

时间: 2024-11-07 01:33:01

移动端手指操控左右滑动的菜单的相关文章

js实现移动端手指左右上下滑动翻页效果

var ele = document.getElementsByClassName("img-box")[0]; var beginX, beginY, endX, endY, swipeLeft, swipeRight; ele.addEventListener('touchstart', function (event) { event.stopPropagation(); event.preventDefault(); beginX = event.targetTouches[0

移动端 触屏滑动条菜单(完善版 转)

移动端 触屏滑动条菜单(完善版) 1 1 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 8

移动端touch触屏滑动事件、滑动触屏事件监听!

移动端touch触屏滑动事件.滑动触屏事件监听! 一.触摸事件 ontouchstart.ontouchmove.ontouchend.ontouchcancel 目前移动端浏览器均支持这4个触摸事件,包括IE.由于触屏也支持MouseEvent,因此他们的顺序是需要注意的:touchstart → mouseover → mousemove → mousedown → mouseup → click1 Apple在iOS 2.0中引入了触摸事件API,Android正迎头赶上这一事实标准,缩小

制作滑动门菜单

在之前的工作中有一次遇到了一种菜单,要随菜单名称的长短而伸展和缩短,后来查了相关资料才知道这种菜单的被称为“滑动门菜单”…… 样子就像下面的图片这样: 做法: 把菜单分成三部分:左边.中间.右边.菜单的左边和右边各用一张背景图片(不平铺),中间用一张背景图片,这张背景图是要平铺的,因为中间部分会随着菜单字数的增多而伸展开来,切图如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http

Android自定义组件——四个方向滑动的菜单实现

今天无意中实现了一个四个方向滑动的菜单,感觉挺好玩,滑动起来很顺手,既然已经做出来了就贴出来让大家也玩弄一下. 一.效果演示 (说明:目前没有安装Android模拟器,制作的动态图片太卡了,就贴一下静态图片吧,实际效果可以下载源代码查看) (向上滑动) (向下滑动) (向左滑动) (向右滑动) 二.实现过程介绍 1.放置5个View (分别是上下左右中) @Override protected void onLayout(boolean changed, int l, int t, int r,

Android自定义组件系列【15】——四个方向滑动的菜单实现

今天无意中实现了一个四个方向滑动的菜单,感觉挺好玩,滑动起来很顺手,目前还没有见过这样的应用,以后能不能在应用中出现或者说有没有实用价值就不好说了,既然已经做出来了就贴出来让大家也玩弄一下,说不定对你有所启发. 一.效果演示 (说明:目前没有安装Android模拟器,制作的动态图片太卡了,就贴一下静态图片吧,实际效果可以下载源代码查看) (向上滑动) (向下滑动) (向左滑动) (向右滑动) 二.实现过程介绍 1.放置5个View (分别是上下左右中) @Override protected v

jQuery滑动导航菜单

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8" /> <meta name="author" content="abangsir" /> <title>jQuery弹性滑动导航菜单</title> <style type="text/css"> body{ font-famil

Android 滑动导航菜单的快速构建(二) Material Design

原创文章,转载请注明 ( 来自:http://blog.csdn.net/leejizhou/article/details/52046748 李济洲的博客 ) 上一篇 http://blog.csdn.net/leejizhou/article/details/52013343 介绍了几个滑动导航菜单效果的快速构建,这篇文章来总结"当下"如何按照Android的设计标准去设计滑动导航菜单,我为什么说的"当下"呢?因为这个设计标准是会变的. 在material de

【前端】css自适应宽度滑动门菜单

html     css    width  自适应 什么是CSS自适应宽度滑动门菜单? CSS自适应宽度菜单指菜单的宽度可以随着内容的增加而变宽,就拿下边的实例来说,是按4个字的宽度来设计的,如果其中一项为5个字或更多,就放不下了.那么我们就需要让它的宽度可以随着内容的增减而变化,这就是css自适应宽度菜单.         自适应宽度按钮的效果是怎样的呢? 那么,自适应宽度按钮,是怎么实现的呢? 要想实现自适应宽度,需要在文字上增加一个辅助标签,如span,分别在a上和span上设置背景,一