zoukankan      html  css  js  c++  java
  • 原生js实现触摸滚动轮播图

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    /* 清除标签默认边距 */
    body,ul,li,ol,img {
    margin: 0;
    padding: 0;
    }

    /* 清除 ul 等标签前面的“小圆点” */
    ul,li,ol {
    list-style-type: none;
    }

    /* 图片自适应 */
    img {
    100%;
    height: auto;
    border: none;
    /* ie8 */
    display: block;
    -ms-interpolation-mode: bicubic; /*为了照顾ie图片缩放失真*/
    }
    /* 轮播图最外层盒子 */
    .carousel {
    position: relative;
    overflow: hidden;
    }

    .carousel ul {
    /* 这个高度需要在JS里面动态添加 */
    }

    .carousel ul li {
    position: absolute;
    100%;
    left: 0;
    top: 0;
    /* 使用 transform:translaX(300%) 暂时将 li 移动到屏幕外面去*/
    -webkit-transform: translateX(300%);
    transform: translateX(300%);
    }

    /* 小圆点盒子 */
    .carousel .points {
    /* 未知宽度的盒子,使用 absolute 定位,结合 transform 的方式进行居中 */
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    }

    /* 小圆点 */
    .carousel .points li {
    5px;
    height: 5px;
    border-radius: 50%;
    border: 1px solid #fff;
    float: left;
    margin: 0 2px;
    }

    /* 选中小圆点的样式类 */
    .carousel .points li.active {
    background-color: #fff;
    }
    </style>
    </head>
    <body>
    <section class="carousel">
    <ul>
    <!-- <li><a href="#"><img src="http://www.25qp.cn/mobile/static/img/banner_02.df6743b.png" alt=""></a></li>
    <li><a href="#"><img src="http://www.25qp.cn/mobile/static/img/banner_03.2da0300.png" alt=""></a></li>
    <li><a href="#"><img src="http://www.25qp.cn/mobile/static/img/banner_01.dcc748a.png" alt=""></a></li> -->
    <li><img src="http://www.25qp.cn/mobile/static/img/banner_02.df6743b.png" alt=""></li>
    <li><img src="http://www.25qp.cn/mobile/static/img/banner_03.2da0300.png" alt=""></li>
    <li><img src="http://www.25qp.cn/mobile/static/img/banner_01.dcc748a.png" alt=""></li>
    </ul>
    <ol class="points"></ol>
    </section>
    <script>
    var carousel = document.querySelector('.carousel');
    var carouselUl = carousel.querySelector('ul');
    var carouselLis = carouselUl.querySelectorAll('li');
    var points = carousel.querySelector('ol');
    // 屏幕的宽度
    var screenWidth = document.documentElement.offsetWidth;
    var timer = null;

    // 设置 ul 的高度
    carouselUl.style.height = carouselLis[0].offsetHeight + 'px';

    // 动态生成小圆点
    for (var i = 0; i < carouselLis.length; i++) {
    var li = document.createElement('li');
    if (i == 0) {
    li.classList.add('active');
    }
    points.appendChild(li);
    }

    // 初始三个固定的位置
    var left = carouselLis.length - 1;
    var center = 0;
    var right = 1;

    // 归位(多次使用,封装成函数)
    setTransform();

    // 调用定时器
    timer = setInterval(showNext, 2000);

    // 分别绑定touch事件
    var startX = 0; // 手指落点
    var startTime = null; // 开始触摸时间
    carouselUl.addEventListener('touchstart', touchstartHandler); // 滑动开始绑定的函数 touchstartHandler
    carouselUl.addEventListener('touchmove', touchmoveHandler); // 持续滑动绑定的函数 touchmoveHandler
    carouselUl.addEventListener('touchend', touchendHandeler); // 滑动结束绑定的函数 touchendHandeler

    // 轮播图片切换下一张
    function showNext() {
    // 轮转下标
    left = center;
    center = right;
    right++;
    // 极值判断
    if (right > carouselLis.length - 1) {
    right = 0;
    }
    //添加过渡(多次使用,封装成函数)
    setTransition(1, 1, 0);
    // 归位
    setTransform();
    // 自动设置小圆点
    setPoint();
    }

    // 轮播图片切换上一张
    function showPrev() {
    // 轮转下标
    right = center;
    center = left;
    left--;
    // 极值判断
    if (left < 0) {
    left = carouselLis.length - 1;
    }
    //添加过渡
    setTransition(0, 1, 1);
    // 归位
    setTransform();
    // 自动设置小圆点
    setPoint();
    }

    // 滑动开始
    function touchstartHandler(e) {
    // 清除定时器
    clearInterval(timer);
    // 记录滑动开始的时间
    startTime = Date.now();
    // 记录手指最开始的落点
    startX = e.changedTouches[0].clientX;
    }
    // 滑动持续中
    function touchmoveHandler(e) {
    // 获取差值 自带正负
    var dx = e.changedTouches[0].clientX - startX;
    // 干掉过渡
    setTransition(0, 0, 0);
    // 归位
    setTransform(dx);
    }
    // 滑动结束
    function touchendHandeler(e) {
    // 在手指松开的时候,要判断当前是否滑动成功
    var dx = e.changedTouches[0].clientX - startX;
    // 获取时间差
    var dTime = Date.now() - startTime;
    // 滑动成功的依据是滑动的距离(绝对值)超过屏幕的三分之一 或者滑动的时间小于300毫秒同时滑动的距离大于30
    if (Math.abs(dx) > screenWidth / 3 || (dTime < 300 && Math.abs(dx) > 30)) {
    // 滑动成功了
    // 判断用户是往哪个方向滑
    if (dx > 0) {
    // 往右滑 看到上一张
    showPrev();
    } else {
    // 往左滑 看到下一张
    showNext();
    }
    } else {
    // 添加上过渡
    setTransition(1, 1, 1);
    // 滑动失败了
    setTransform();
    }

    // 重新启动定时器
    clearInterval(timer);
    // 调用定时器
    timer = setInterval(showNext, 2000);
    }
    // 设置过渡
    function setTransition(a, b, c) {
    if (a) {
    carouselLis[left].style.transition = 'transform 1s';
    } else {
    carouselLis[left].style.transition = 'none';
    }
    if (b) {
    carouselLis[center].style.transition = 'transform 1s';
    } else {
    carouselLis[center].style.transition = 'none';
    }
    if (c) {
    carouselLis[right].style.transition = 'transform 1s';
    } else {
    carouselLis[right].style.transition = 'none';
    }
    }

    // 封装归位
    function setTransform(dx) {
    dx = dx || 0;
    carouselLis[left].style.transform = 'translateX(' + (-screenWidth + dx) + 'px)';
    carouselLis[center].style.transform = 'translateX(' + dx + 'px)';
    carouselLis[right].style.transform = 'translateX(' + (screenWidth + dx) + 'px)';
    }
    // 动态设置小圆点的active类
    var pointsLis = points.querySelectorAll('li');

    function setPoint() {
    for (var i = 0; i < pointsLis.length; i++) {
    pointsLis[i].classList.remove('active');
    }
    pointsLis[center].classList.add('active');
    }
    </script>
    </body>
    </html>

  • 相关阅读:
    感悟.学习的方式
    IOS地理信息使用
    IOSTimer的例子留个备注
    IOSSelector的用法
    ios中addtarget的用法
    ios绘图时的坐标处理
    mac下装Ruby
    iOSbase64
    ios跳转
    Misha and Palindrome Degree CodeForces
  • 原文地址:https://www.cnblogs.com/studyh5/p/10598977.html
Copyright © 2011-2022 走看看