<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no">
<meta name="applicable-device" content="mobile" />
<meta content="yes" name="apple-mobile-web-app-capable"/>
<meta name="apple-mobile-web-app-status-bar-style" content="black" />
<meta content="telephone=no" name="format-detection"/>
<title>无标题文档</title>
</head>
<style>
*{ font-size:14px; padding:0; margin:0;}
.tab{ margin:10px;}
.tit{ height:30px; width:100%; border:1px solid #ccc; line-height:30px;}
.tit span{ display:inline-block; height:30px; line-height:30px; width:24%; border-right:1px solid #ccc; text-align:center}
.tit .cur{ color:#fff; background-color:#ccc;}
ul{overflow:hidden;zoom:1; width:300px; float:left}
ul li{ height:30px; line-height:30px; white-space:nowrap; overflow:hidden}
.tab-wrap{ position:relative; height:150px; overflow:hidden;zoom:1;}.tab-main{ position:absolute; left:0px; top:0px;}
</style>
<body> <div class="tab" id="tap">
<div class="tit"><span class="cur">新闻</span><span>体育</span><span>娱乐</span><span>文化</span></div>
<div class="tab-wrap">
<div class="tab-main">
<ul class="current">
<li>新闻新闻新闻新闻新闻新闻新闻新闻新闻</li>
<li>新闻新闻新闻新闻新闻新闻新闻新闻新闻</li>
<li>新闻新闻新闻新闻新闻新闻新闻新闻新闻</li>
<li>新闻新闻新闻新闻新闻新闻新闻新闻新闻</li>
<li>新闻新闻新闻新闻新闻新闻新闻新闻新闻</li>
</ul>
<ul>
<li>体育体育体育体育体育体育体育体育体育</li>
<li>体育体育体育体育体育体育体育体育体育体育体育体育</li>
<li>体育体育体育体育体育体育体育体育体育体育</li>
<li>体育体育体育体育体育体育体育体育体育体育</li>
<li>体育体育体育体育体育体育体育体育体育体育体育</li>
</ul>
<ul>
<li>娱乐娱乐娱乐娱乐娱乐娱乐娱乐</li>
<li>娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐</li>
<li>娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐</li>
<li>娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐</li>
<li>娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐娱乐</li>
</ul>
<ul>
<li>文化文化文化文化文化文化文化文化文化文化文化</li>
<li>文化文化文化文化文化文化文化文化文化文化</li>
<li>文化文化文化文化文化文化文化文化文化文化</li>
<li>文化文化文化文化文化文化文化文化文化文化文化文化</li>
<li>文化文化文化文化文化文化文化文化文化文化</li>
</ul>
</div>
</div>
</div> <script src="js/jquery.js"></script>
<script> $('ul').width($(window).width()-20);
var oulWidth=$('ul').width();
var oulLength=$('ul').length;
var timer=null;
var i=0;
var j=0;
$('.tab-main').width(oulWidth*oulLength); $(".tab-main").on("touchstart", function(e) {
e.preventDefault();
clearInterval(timer)
startX = e.originalEvent.changedTouches[0].pageX,
startY = e.originalEvent.changedTouches[0].pageY;
});
$(".tab-main").on("touchmove", function(e) {
e.preventDefault();
moveEndX = e.originalEvent.changedTouches[0].pageX,
moveEndY = e.originalEvent.changedTouches[0].pageY,
X = moveEndX - startX,
Y = moveEndY - startY;
}); $(".tab-main").on("touchend", function(e) {
e.preventDefault();//阻止默认触屏滑动
if ( Math.abs(X) > Math.abs(Y) && X > 0 ) { //向左
if(i==0){
i=oulLength-1;
$('.tab-main ul').eq(i).css({'position':'relative','left':-oulWidth*oulLength+'px'});
}else{
i--
};
j--;
$('.tab-main').animate({'left':-j*oulWidth});
$('.tit span').eq(j).addClass('cur').siblings().removeClass('cur');
$('.tab-main').stop().animate({'left':-j*oulWidth+'px'},function(){
if(i==oulLength-1){
$('.tab-main ul').eq(oulLength-1).css({'position':'static'});
$('.tab-main').css('left',-oulWidth*(oulLength-1));
j=oulLength-1;
};
});
}else if ( Math.abs(X) > Math.abs(Y) && X < 0 ) {//向右
rightAuto()
}else if ( Math.abs(Y) > Math.abs(X) && Y > 0) {//向下
alert("top 2 bottom");
}else if ( Math.abs(Y) > Math.abs(X) && Y < 0 ) {//向上
alert("bottom 2 top");
}else{//点击
alert("just touch");
};
timer=setInterval(rightAuto,5000);
});
//右滚动函数
function rightAuto(){
if(i==oulLength-1){
i=0;
$('.tab-main ul').eq(0).css({'position':'relative','left':oulWidth*oulLength+'px'});
}else{
i++
};
j++
$('.tab-main').animate({'left':-j*oulWidth});
$('.tit span').eq(i).addClass('cur').siblings().removeClass('cur');
$('.tab-main').stop().animate({'left':-j*oulWidth+'px'},function(){
if(i==0){
$('.tab-main ul').eq(0).css({'position':'static'});
$('.tab-main').css('left',0);
j=0;
};
})
};
//定时轮播
timer=setInterval(rightAuto,5000); </script>
</body>
</html>

 

步骤解释:

 1.主要运用touchstart,touchmove,touchend三个事件;当touched结束时根据滑动的距离执行判断

Math.abs(X) > Math.abs(Y) 是向左右,向右,上,下,当然写在次出还有些bug,因为滑动屏幕的时候不会很直,会斜上或者斜下,因此加上“&& X < 0 ”判断更准确一些;

2.有了判断结果,然后根据相应的结果写出滑动的效果,此处我觉得和pc写法差别不大;

3. 然后就是定时滚动,此处和pc也不是很大区别,最后一点就是当进行touchstart的时候,clearInterval(timer)清除定时器,当touchend的时候,再进行滚动

ok,在此基本完成

jquery 触屏滑动+定时滚动的更多相关文章

  1. 朋友圈常见单页面触屏滑动上下翻屏功能jQuery实现

    翻页插件:实现原理,用margin-top来控制页面容器位置来实现上下翻页.margin这属性很好用,可以用来制作侧栏动画滑出菜单(左菜单,右内容,控制两者的margin实现):或者head下滑菜单 ...

  2. TouchSlide 触屏滑动特效插件

    TouchSlide 是纯javascript打造的触屏滑动特效插件,面向手机.平板电脑等移动终端,能实现触屏焦点图.触屏Tab切换.触屏多图切换等常用效果. 插件开源.体积小.简单实用.功能强大,是 ...

  3. touch移动触屏滑动事件

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  4. JS移动客户端--触屏滑动事件

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  5. jquery触屏幻灯片

    一.前言 去年接触了移动Web开发,做了些手机端的网站及应用,还有些小的微信游戏和活动页面.每个项目里或多或少的都会有一些触屏事件等.其中有两个用到了jquery触屏幻灯片.刚开始的时候也在百度上搜索 ...

  6. JS移动客户端--触屏滑动事件 banner图效果

    JS移动客户端--触屏滑动事件 移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的t ...

  7. JS案例之5——移动端触屏滑动

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  8. js实现touch移动触屏滑动事件

    在开始描述touch事件之前,需要先描述一下多触式系统中特有的touch对象(android和iOS乃至nokia最新的meego系统都模拟了类 似的对象).这个对象封装一次屏幕触摸,一般来自于手指. ...

  9. 移动端触屏滑动,JS事件

    先了解下 移动端的触屏滑动 毕竟这玩意其实和PC端还是有一定的区别的 hh 整理了下网上的资料放一放 移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等 ...

随机推荐

  1. 安卓模拟器错误: Could not open

    在进行android模拟器測试的时候,出现下面错误,进度条满了之后就没反应了.图例如以下: 引起这个问题的可能原因有非常多: 原因一:由于我们採用的是绝对路径定位.也就是说在环境变量里面把路径写死了, ...

  2. 补间动画实现(tween)

    1.补间动画的概念: 补间动画:仅仅须要开发人员设置好动画的開始与结束的关键帧 中间帧有喜用计算机补齐. 2.种类:分为4种: ①alpha 透明度 ②alpha 透明度 ③translate 位置移 ...

  3. HDU 3172 Virtual Friends(并用正确的设置检查)

    职务地址:pid=3172">HDU 3172 带权并查集水题.每次合并的时候维护一下权值.注意坑爹的输入. . 代码例如以下: #include <iostream> # ...

  4. 35,000FT大气压力的问题

    原来的问题:压力在喷气客机的飞行FL350(35,000脚)大约210mmHg.这是个大气压的数量? 在每平方英寸磅? 多少帕斯卡尔? http://wenwen.sogou.com/z/q33797 ...

  5. NYoj WAJUEJI which home strong!(简单搜索)

    题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=1100 这道题,自己初写搜索,给学长气的只打我,Orz....... 搜索的思路要理 ...

  6. Oracle内存管理(五)

    [深度分析--eygle]学习笔记 1.4. 2其他内存组件 Large Pool-大池是SGA的一个可选组件,通经常使用于共享server模式(MTS). 并行计算或 RMAN的备份恢复等操作. J ...

  7. 在Mac电脑上为Dash制作docSet文档

    Dash是mac上的一款查看API的工具,里面能够直接下载大部分的API文档,可是有时候我们假设想把自己手里已有的文档也集成到Dash中,就须要我们自己动手了,事实上Dash官方也有教程怎样制作doc ...

  8. The Swift Programming Language-官方教程精译Swift(7)函数 -- Functions

    函数 函数是执行特定任务的代码自包含块.通过给定一个函数名称标识它是什么,并在需要的时候使用该名称来调用函数以执行任务. Swift的统一的功能语法足够灵活的,可表达任何东西,无论是不带参数名称的简单 ...

  9. JS怎样将拖拉事件与点击事件分离?

    帖子:http://bbs.csdn.net/topics/390785395?page=1#post-397369340 怎样将拖拉事件跟点击事件分离? 须要做到:拖拉时不触动点击事件 <ht ...

  10. 将已有的工程项目添加到Xcode到Git管理中

    在Xcode中创建工程的时候,我们很容易的可以将新创建的工程添加到Git中,如图: 但是如果是本地已经有的工程,那该如何添加到Git中呢? 首先终端进入到该工程的目录. 然后: git init gi ...