这个轮播代码不是我自己所写,是偶然游览一个简友的主页看到的,今天刚看了事件,决定来逐行分析一下这个代码。首先,移动端与电脑端不同的是移动端只能通过触摸和手势来发生行为,所以我们要用到js中的与触摸操作有关的新事件。其实我们轮播的原理和以前相同,都是通过改变元素的位置来控制图片的出现,但让我们不是很上手的,是那些用于跟踪触摸的属性。

下面,我简单介绍一下与触摸相关的知识
触摸事件
上面这几个事件都会冒泡,也都可以取消。
属性
每个touch对象包括下列属性
代码如下
<!DOCTYPE html>
<html>
<head>
<title>移动端轮播</title>
<style type="text/css">
* {
margin: 0;
padding: 0;
}
#box {
width: 980px;
overflow: hidden;
position: relative;
margin: 0 auto;
}
#box ul {
width: 4900px;
height: 100px;
position: relative;
transform: translateX(-980px);
}
#box ul li{
width: 980px;
height: 100px;
float: left;
list-style-type: none;
text-align: center;
color: #fff;
line-height: 100px;
font-size: 30px;
}
</style>
<script type="text/javascript">
window.onload = function() {
var box = document.getElementById('box');
var oUl = document.getElementsByTagName('ul')[0];
var aLi = oUl.children;//这样就可以把所有li标签获取到了
var iNow = 1;
var x = -iNow*aLi[0].offsetWidth;//li标签的位置
var bReady = true;
oUl.addEventListener('touchstart',function(ev){
//当手指触摸屏幕的时候触发事件,让li的位置随手指滑动而改变
if(bReady == false){return;}
bReady = false;
var downX = ev.targetTouches[0].pageX; //记录触摸位置
var disX = downX - x;//下一个li要移动到的位置
function fnMove(ev) {
x = downX-disX;
oUl.style.transform = 'translate3d('+x+'px,0,0)';
}
function fnEnd(ev){
var upX = ev.changedTouches[0].pageX;//离开的位置
if(Math.abs(upX - downX)>50){
//左边移动
if(upX - downX<0){
iNow++;
if(iNow==aLi.length){iNow=aLi.length-1;}
}else{
//右边移动
iNow--;
if(iNow==-1){iNow=0;}
}
}
x = -iNow*aLi[0].offsetWidth;
oUl.style.transform = 'translate3d('+x+'px,0,0)';
oUl.style.transition = '200ms all ease';
function tEnd(){
if(iNow==4){
iNow=1;
}
if(iNow==0){iNow=3;}
oUl.style.transition = 'none'
x = -iNow*aLi[0].offsetWidth;
oUl.style.transform = 'translate3d('+x+'px,0,0)';
bReady = true;
}
oUl.addEventListener('transitionend',tEnd,false);
//释放内存
document.removeEventListener('touchend',fnEnd,false);
document.removeEventListener('touchmove',fnMove,false);
}
document.addEventListener('touchmove',fnMove,false);
document.addEventListener('touchend',fnEnd,false);
//阻止默认事件
ev.preventDefault();
},false);
}
</script>
</head>
<body>
<div id="box">
<ul>
<li style="background:green">3</li>
<li style="background:orange">1</li>
<li style="background:yellow">2</li>
<li style="background:green">3</li>
<li style="background:orange">1</li>
</ul>
</div>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# 移动端
# 轮播
# 原生js实现移动端触摸轮播的示例代码
# js实现移动端轮播图效果
# 支持移动端原生js轮播图
# 原生js图片轮播效果实现代码
# js原生实现移动端手指滑动轮播图效果的示例
# 的是
# 都是
# 口中
# 放在
# 看了
# 一只
# 也会
# 在这个
# 让我们
# 可以用
# 屏幕上
# 不是很
# 要用
# 也都
# 这几个
# 介绍一下
# 发生了什么
# 移开
# 所写
# 大家多多
相关文章:
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
如何快速搭建FTP站点实现文件共享?
建站主机助手选型指南:2025年热门推荐与高效部署技巧
网站制作公司排行榜,抖音怎样做个人官方网站
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
宝塔建站助手安装配置与建站模板使用全流程解析
桂林网站制作公司有哪些,桂林马拉松怎么报名?
如何快速上传建站程序避免常见错误?
建站之星安装路径如何正确选择及配置?
如何高效配置IIS服务器搭建网站?
如何通过NAT技术实现内网高效建站?
如何快速配置高效服务器建站软件?
自助网站制作软件,个人如何自助建网站?
,怎么在广州志愿者网站注册?
建站之星备案是否影响网站上线时间?
如何选择香港主机高效搭建外贸独立站?
如何安全更换建站之星模板并保留数据?
如何快速辨别茅台真假?关键步骤解析
建站之星代理商如何保障技术支持与售后服务?
再谈Python中的字符串与字符编码(推荐)
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
如何访问已购建站主机并解决登录问题?
淘宝制作网站有哪些,淘宝网官网主页?
深圳网站制作培训,深圳哪些招聘网站比较好?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
已有域名和空间如何搭建网站?
建站主机空间推荐 高性价比配置与快速部署方案解析
,南京靠谱的征婚网站?
建站之星伪静态规则如何正确配置?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
C++如何使用std::optional?(处理可选值)
香港服务器网站卡顿?如何解决网络延迟与负载问题?
如何选择网络建站服务器?高效建站必看指南
如何获取上海专业网站定制建站电话?
如何通过服务器快速搭建网站?完整步骤解析
建站之星如何配置系统实现高效建站?
网站专业制作公司有哪些,做一个公司网站要多少钱?
javascript中的try catch异常捕获机制用法分析
如何选择服务器才能高效搭建专属网站?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何在七牛云存储上搭建网站并设置自定义域名?
如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本
高端网站建设与定制开发一站式解决方案 中企动力
已有域名如何免费搭建网站?
建站VPS配置与SEO优化指南:关键词排名提升策略
如何在阿里云完成域名注册与建站?
音乐网站服务器如何优化API响应速度?
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
*请认真填写需求信息,我们会在24小时内与您取得联系。