移动端滑动轮播,原生JS

因为公司需要自定义两个轮播图联动,又不想引入第三方库,所以自己研究了下。

下面只是一个简单的轮播图,由此再拓展一下即可实现两个轮播图联动。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <title>Document</title>
</head>
<style>
    html{height:100%;}
    body{width: 100%;height:100%;margin:0;overflow: hidden;}
    .wrap{position: relative;overflow: hidden;}
    .box{position: absolute;list-style: none;left:0;top:0;padding:0;margin:0;}
    .box li{float:left;}
    .box{
        position: relative;
        height: 200px;
        width: 100%;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        background: red;

        transition: left 0.5s;
        -moz-transition: left 0.5s;    /* Firefox 4 */
        -webkit-transition: left 0.5s;    /* Safari 和 Chrome */
        -o-transition: left 0.5s;    /* Opera */
    }
    .box1{
        height: 200px;
    }
    .box2{
        background: yellow;
    }
    .box3{
        background: yellowgreen;
    }
    .box4{
        background: orange;
    }
    .box5{
        background: cyan;
    }
</style>
<body>
<div class="wrap">
    <ul class="box">
        <li><div class="box1 box2">11111</div></li>
        <li><div class="box1 box3">2222</div></li>
        <li><div class="box1 box4">3333</div></li>
        <li><div class="box1 box5">4444</div></li>
    </ul>
</div>
<script>
  // 获取dom对象
  var aLi = document.querySelectorAll('.box li');
  var box = document.querySelector('.box');
  var wrap = document.querySelector('.wrap');
  var aLiWidth = box.offsetWidth;
  
  var disX = 0;   //滑动距离
  var currNum = 0;      //当前索引
  
  // 布局
  wrap.style.height = aLi[0].offsetHeight+'px';
  box.style.width = aLi.length*100+'%';
  aLi.forEach(function(item,index){
    item.style.width = aLiWidth+'px';
  })

  // 初始化手指坐标点
  var startPoint = 0;
  var startEle = 0;
  // 手指按下--获取手指位置和box的位置
  wrap.addEventListener('touchstart',function(e){
    startPoint = e.changedTouches[0].pageX;
    startEle = box.offsetLeft;
    console.log(startEle);
  });
  // 手指滑动 
  wrap.addEventListener('touchmove',function(e){
    var currPoint = e.changedTouches[0].pageX;
    disX = currPoint-startPoint;
    var left = startEle+disX/2;
    box.style.transition = 'left 0s';
    box.style.left = left + 'px';
    // console.log(disX);   //手指滑动距离
  });
  //当手指抬起的时候,判断图片滚动离左右的距离
  wrap.addEventListener('touchend',function(e){
    var left = box.offsetLeft;
    // 判断正在滚动的图片的滚动距离和方向,以及是否是第一张或最后一张
    if(disX>100){   //向右滑动100px时
      currNum = Math.floor(-left/aLiWidth);
      currNum = currNum<=0 ? 0 : currNum;
    }else if(disX<-100){   //向左滑动100px时
      currNum = Math.floor(-left/aLiWidth)+1;
      currNum = currNum>=(aLi.length-1) ? aLi.length-1 : currNum;
    };
    box.style.transition = 'left 0.5s';
    box.style.left = -currNum*wrap.offsetWidth + 'px';
  })



</script>

</body>
</html>
<!DOCTYPE html >
< html lang= "en" >
< head >
< meta charset= "UTF-8" >
< meta name= "viewport" content= "width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" >
< title >Document </ title >
</ head >
< style >
html{ height: 100%;}
body{ width: 100%; height: 100%; margin: 0; overflow: hidden;}
.wrap{ position: relative; overflow: hidden;}
.box{ position: absolute; list-style: none; left: 0; top: 0; padding: 0; margin: 0;}
.box li{ float: left;}
.box{
position: relative;
height: 200px;
width: 100%;
top: 0;
bottom: 0;
left: 0;
right: 0;
background: red;

transition: left 0.5s;
-moz-transition: left 0.5s/* Firefox 4 */
-webkit-transition: left 0.5s;   /* Safari 和 Chrome */
-o-transition: left 0.5s/* Opera */
}
.box1{
height: 200px;
}
.box2{
background: yellow;
}
.box3{
background: yellowgreen;
}
.box4{
background: orange;
}
.box5{
background: cyan;
}
< / style >
< body >
< div class= "wrap" >
< ul class= "box" >
< li >< div class= "box1 box2" >11111 </ div ></ li >
< li >< div class= "box1 box3" >2222 </ div ></ li >
< li >< div class= "box1 box4" >3333 </ div ></ li >
< li >< div class= "box1 box5" >4444 </ div ></ li >
</ ul >
</ div >
< script >
// 获取dom对象
var aLi = document. querySelectorAll( '.box li');
var box = document. querySelector( '.box');
var wrap = document. querySelector( '.wrap');
var aLiWidth = box. offsetWidth;
 
var disX = 0; //滑动距离
var currNum = 0; //当前索引
 
// 布局
wrap. style. height = aLi[ 0]. offsetHeight+ 'px';
box. style. width = aLi. length* 100+ '%';
aLi. forEach( function( item, index){
item. style. width = aLiWidth+ 'px';
})

// 初始化手指坐标点
var startPoint = 0;
var startEle = 0;
// 手指按下--获取手指位置和box的位置
wrap. addEventListener( 'touchstart', function( e){
startPoint = e. changedTouches[ 0]. pageX;
startEle = box. offsetLeft;
console. log( startEle);
});
// 手指滑动
wrap. addEventListener( 'touchmove', function( e){
var currPoint = e. changedTouches[ 0]. pageX;
disX = currPoint- startPoint;
var left = startEle+ disX/ 2;
box. style. transition = 'left 0s';
box. style. left = left + 'px';
// console.log(disX); //手指滑动距离
});
//当手指抬起的时候,判断图片滚动离左右的距离
wrap. addEventListener( 'touchend', function( e){
var left = box. offsetLeft;
// 判断正在滚动的图片的滚动距离和方向,以及是否是第一张或最后一张
if( disX> 100){ //向右滑动100px时
currNum = Math. floor(- left/ aLiWidth);
currNum = currNum<= 0 ? 0 : currNum;
} else if( disX<- 100){ //向左滑动100px时
currNum = Math. floor(- left/ aLiWidth)+ 1;
currNum = currNum>=( aLi. length- 1) ? aLi. length- 1 : currNum;
};
box. style. transition = 'left 0.5s';
box. style. left = - currNum* wrap. offsetWidth + 'px';
})



< / script >

</ body >
</ html >

猜你喜欢

转载自www.cnblogs.com/LChenglong/p/9372438.html