swiper 封装
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">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <link rel="stylesheet" href="./css/swiper.css">
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        ul {
            list-style: none;
        }
        html, body, #app {
            width: 100%;
            height: 100%;
            overflow: hidden;
        }
        .gap{
            height:50px;
        }
    </style>
    <script src="https://cdn.bootcss.com/holder/2.9.6/holder.min.js"></script>
</head>
<body>
<div id="app">
    <div id="swiper">
        <!---->
        <div class="swiper-wrapper">
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#999" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#aef" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#90a" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#b98" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#b41" alt=""></div>
        </div>
        <div class="swiper-pagination"></div>
    </div>
    <div class="gap"></div>
    <div id="swiper2">
        <!---->
        <div class="swiper-wrapper">
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#999" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#aef" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#90a" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#b98" alt=""></div>
            <div class="swiper-slide"><img src="holder.js/100px100?bg=#b41" alt=""></div>
        </div>
        <div class="swiper-pagination"></div>
    </div>
</div>
<script src="./js/transformCSS.js"></script>
<script src="./js/swiper.js"></script>
<script>
    var app = document.querySelector('#app');
    app.addEventListener('touchstart', function (e) {
        e.preventDefault();
    });
new Swiper('#swiper');
    new Swiper('#swiper2',{
        pagination: false
    });
</script>
</body>
</html>
-------------------------------------
swiper.css
.swiper-slide {
    float: left;
}
.swiper-pagination {
    z-index: 2;
    position: absolute;
    width: 100%;
    height: 10px;
    left: 0;
    bottom: 10px;
    line-height: 10px;
    text-align: center;
}
.swiper-pagination span {
    display: inline-block;
    width: 10px;
    height: 10px;
    background: white;
    border-radius: 50%;
    margin-right: 4px;
}
.swiper-pagination .active {
    background: darkorange;
}
--------------------------------------
transformCSS.js
/*
    函数
    transformCSS
    作用
    1. 快速设置元素的 transform 变形   ele.style.transform = 'translateX(100px)';
    transformCSS(ele, 'translateX', 100);
    transformCSS(ele, 'translateY', 100);
    transformCSS(ele, 'rotate', 50);
    transformCSS(ele, 'scale', 2);
    transformCSS(ele, 'scaleY', 1);
    2. 读取元素 transform 变形值
    transformCSS(ele, 'translateX'); // 100
    transformCSS(ele, 'rotate'); // 50
    prop  property 属性
    val   value    属性值
    #box{
        left:100px;
        transform: translateX(100px)
    }
 */
/**
 *
 * @param el     元素对象
 * @param prop   变形的样式
 * @param val    变形的样式值
 *
 * 多次的设置 需要保存前面的样式
 * translateX  100
 * rotate      45
 *
 */
// transformCSS(box, 'translateX', 200);
// var styles = {};//  {translateX: 100}
//
(function (w) {
    function transformCSS(el, prop, val) {
        //初始化样式仓库
        if (el.store === undefined) {
            el.store = {};
        }
        //设置
        if (arguments.length == 3) {
            el.style.transform = prop + '(' + val + 'px)';
            //向对象中存入参数
            el.store[prop] = val;
            //设置样式
            /**
             *
             * {translateX: 200, rotate: 45, scale: 3}
             ||
             ||
             ||
             \/
             transform: translateX(200px)  rotate(45deg)  scale(3);
             */
            var str = '';
            for (var i in el.store) {
                // i  translateX  rotate scale
                // styles[i]  200    45    3
                switch (i) {
                    case 'translateX':
                    case 'translateY':
                    case 'translateZ':
                        str += i + '(' + el.store[i] + 'px) ';
                        break;
                    case 'rotate':
                    case 'rotateX':
                    case 'rotateY':
                    case 'rotateZ':
                        str += i + '(' + el.store[i] + 'deg) ';
                        break;
                    case 'scale':
                    case 'scaleX':
                    case 'scaleY':
                    case 'scaleZ':
                        str += i + '(' + el.store[i] + ') ';
                        break;
                }
                //设置变形样式
                el.style.transform = str;
            }
        }
        //样式读取
        if (arguments.length == 2) {
            //判断 如果设置了 则返回设置的值
            if (el.store[prop]) {
                return el.store[prop];
            }
            //如果没有设置  translate  rotate  0   scale  1  scaleX  scaleY  scaleX  scale
            //判断样式是否以 scale 开头
            var start = prop.substr(0, 5);
            if (start === 'scale') {
                return 1;
            } else {
                return 0;
            }
        }
    }
w.transformCSS = transformCSS;
})(window);
-----------------------------
swiper.js
/**
 封装一个函数用来实现幻灯片效果
 函数名
 Swiper
 使用示例
 new Swiper('#swiper-container');
 new Swiper('#swiper-container', {
            auto: false,
            loop: false,//无缝滚动
            time: 5000,
            pagination: true
        });
 依赖:
 transformCSS.js
 */
// new Swiper('#swiper', {
//     loop: true,
// })
function Swiper(selector, options) {
    //处理 options 选项
    // var auto = true;
    // if (options) {
    //     if (options.auto === undefined) {
    //         //设置默认值的情况
    //         auto = true;
    //     } else {
    //         auto = options.auto;
    //     }
    // }
    var auto = options && options.auto !== undefined ? options.auto : true;
    //处理 loop 参数
    // var loop = true;
    // if (options) {
    //     if (options.loop === undefined) {
    //         //设置默认值的情况
    //         loop = true;
    //     } else {
    //         loop = options.loop;
    //     }
    // }
    var loop = options && options.loop !== undefined ? options.loop : true;
    // var time = 2000;
    // if (options) {
    //     if (options.time === undefined) {
    //         //设置默认值的情况
    //         time = 2000;
    //     } else {
    //         time = options.time;
    //     }
    // }
    var time = options && options.time !== undefined ? options.time : 2000;
    // var page = true;
    // if (options) {
    //     if (options.pagination === undefined) {
    //         //设置默认值的情况
    //         page = true;
    //     } else {
    //         page = options.pagination;
    //     }
    // }
var page = options && options.pagination !== undefined ? options.pagination : true;
    //获取元素  isDown
    var container = document.querySelector(selector);
    console.log(container);
    var wrapper = container.querySelector('.swiper-wrapper');
    var index = 0;//当前显示的幻灯片的下标
    var dots = null;
    var len = container.querySelectorAll('.swiper-slide').length;// 5
    var pagination = container.querySelector('.swiper-pagination');
    var timer = null;
    if (loop) {
        //无缝滚动
        wrapper.innerHTML += wrapper.innerHTML;
    }
    var length = container.querySelectorAll('.swiper-slide').length;// 5
    //标识变量
    var isHori = true;// is 是否  hori  水平
    var isFirst = true;// first 第一次
    //触摸开始事件
    container.addEventListener('touchstart', function (e) {
        wrapper.style.transition = 'none';
        //获取按下时的时间点
        this.touchstartTime = Date.now();
        //判断无缝滚动
        if (loop) {
            //判断 无缝滚动的幻灯片
            if (index == 0) {
                index = len;
                container.switchSlide(index, false);
            }
            //右侧边界
            if (index == length - 1) {
                index = len - 1;
                container.switchSlide(index, false);
            }
        }
        //获取触摸开始时的触点位置
        this.x = e.touches[0].clientX;
        this.y = e.touches[0].clientY;
        //获取包裹元素的水平偏移量
        // this.left = wrapper.offsetLeft;// translateX 的偏移值
        //获取元素的 transform 样式值
        this.left = transformCSS(wrapper, 'translateX');
        //停止定时器
        clearInterval(timer);
    });
    //触摸滑动时事件
    container.addEventListener('touchmove', function (e) {
        //获取当前的触点位置
        this._x = e.touches[0].clientX;
        //获取移动后的触点位置
        this._y = e.touches[0].clientY;
        //垂直方向上的偏移
        var disY = Math.abs(this._y - this.y);
        var disX = Math.abs(this._x - this.x);
        if (isFirst) {
            //标识变量赋值为 假
            isFirst = false;
            //判断方向
            if (disY > disX) {
                isHori = false;
            }
            if (disY < disX) {
                isHori = true;
            }
        }
        //判断方向 决定是否阻止默认行为
        if (isHori) {
            e.preventDefault();
        } else {
            return;
        }
        //计算新的left 值
        var newLeft = this._x - this.x + this.left;
        //设置 left 的值
        // wrapper.style.left = newLeft + 'px';
        //设置元素的 translateX 样式
        // wrapper.style.transform = 'translateX('+newLeft+'px)';
        transformCSS(wrapper, 'translateX', newLeft);
    });
    //触摸结束事件
    container.addEventListener('touchend', function (e) {
        //重新赋值变量
        isFirst = true;
        //启动定时器
        this.autoRun();
        //如果是垂直滑动
        if (!isHori) return;
        //获取触摸结束时触点位置
        this._x = e.changedTouches[0].clientX;
        //判断距离
        var disX = Math.abs(this._x - this.x);
        //判断时间
        this.touchendTime = Date.now();
        if (disX > container.offsetWidth / 2 || this.touchendTime - this.touchstartTime <= 300) {
            // 向左滑动
            if (this._x < this.x) {
                index++
            }
            //
            if (this._x > this.x) {
                index--;
            }
        }
        //检测是否越界
        if (index < 0) {
            index = 0;
        }
        if (index > length - 1) {
            index = length - 1;
        }
        // index   =>  left 的关系
        // 0      1       2      N
        // 0    -375    -750    -375*N
        //增加过渡
        this.switchSlide(index);
    });
    //动画过渡完毕事件  transitionend
    loop && wrapper.addEventListener('transitionend', function () {
        //是不是最后一张幻灯片
        if (index == length - 1) {
            //移除过渡
            index = len - 1;
            container.switchSlide(index, false);
        }
    });
    //初始化
    container.init = function () {
        //设置容器元素的相对定位
        container.style.position = 'relative';
        //获取第一个幻灯片的高度
        var slides = container.querySelectorAll('.swiper-slide');
        //容器设置 高度
        window.addEventListener('load', function () {
            var h = slides[0].offsetHeight;
            //设置容器的高度
            container.style.height = h + 'px';
        });
        //包裹元素的宽度设置
        wrapper.style.width = length * 100 + '%';
        //设置子元素的宽度
        slides.forEach(function (slide) {
            //设置宽度
            slide.style.width = 100 / length + '%';
        });
        //如果设置为真 则创建导航点
        if (page) {
            //根据幻灯片数量动态创建导航点
            for (var i = 0; i < len; i++) {
                //创建span 标签
                var span = document.createElement('span');
                if (i == 0) {
                    span.className = 'active';
                }
                //插入到导航元素中
                pagination.appendChild(span);
            }
            //获取导航点元素
            dots = container.querySelectorAll('.swiper-pagination span');
        }
    }
    container.init();
    //自动播放
    container.autoRun = function () {
        if (!auto) return;
        //防止定时器重复
        clearInterval(timer);
        //启动定时器
        timer = setInterval(function () {
            //索引自增 切换幻灯片
            index++;
            //增加过渡
            wrapper.style.transition = 'all 0.5s';
            container.switchSlide(index);
            //index  9   index  4
        }, time);
    }
    container.autoRun();
    //切换幻灯片的功能   switchSlide(3)
    container.switchSlide = function (i, isTransition) {
        //如果没有传参  默认为过渡切换
        if (isTransition === undefined) {
            isTransition = true;
        }
        if (isTransition) {
            wrapper.style.transition = 'all 0.5s';
        } else {
            wrapper.style.transition = 'none';
        }
        //计算新的left 的值
        var newLeft = -i * container.offsetWidth;
        //设置 left 的样式
        // wrapper.style.left = newLeft + 'px';
        // wrapper.style.transform = 'translateX('+newLeft+'px)';
        transformCSS(wrapper, 'translateX', newLeft);
        //点的切换
        if (page) {
            //移除所有导航点 active 类
            dots.forEach(function (dot) {
                // removeClass   addClass
                dot.classList.remove('active');
            });
            //当前索引的导航点 增加 active 类  dots  4   i 5 6 7 8 9
            dots[i % len].classList.add('active');
        }
        //设置当前的显示下标为 i
        index = i;
    }
}
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号