使用原生JS实现移动端图片轮播效果(二)

作者: 前端一小卒 | 来源:发表于2017-02-17 17:34 被阅读1712次

在上篇文章中,使用改变left的值实现轮播效果,在PC端上因为要兼容旧版浏览器,所以都采用这种做法。但是在移动端上会使浏览器造成极大的性能开销,在一些老机型中会出现明显的卡顿,用户体验不好,所以在这篇文章中将使用translate实现轮播。translate样式的变化会造成重绘,但是并不会进行CSS样式的重新计算和布局,其性能要明显优于left。

在整体结构不变的前提下,只是更改了其JS文件就能实现相关效果,为了能够更好的更改和读取其translateX的值,所以写了一个相关的函数。

// 只传入两个实参则为获取,传入三个实参为设置参数值,当然为了简单点,所以只加入了translateX这一单一属性,用户可以自行对该函数进行改造,
//可以适当的加入translateY,scaleX,scaleY等值。
    function cssTransform(ele,attr,val){
        if(!ele.transform){
            ele.transform = {};
        };
//当传入值时对属性进行设置。
        if(arguments.length>2){
            ele.transform[attr] = val;
            var sval = "";
            for(var s in ele.transform){
                if(s == "translateX"){
                    sval += s + "("+ele.transform[s] +"px)";
                }
                ele.style.WebkitTransform = ele.style.transform = sval;
            }
            
        }else{
            val = ele.transform[attr];
            if(typeof val=="undefined"){
                if(attr=="translateX"){
                    val = 0;
                }
            };
            console.log(val);
            return val;
        }
    }

在代码中,有几个重要的点,掌握其原理之后,移动端轮播就基本可以了。

1.在页面刚加载时,设置盒子的translateX为0,并取消定时器。
2.当手指按下的时候,取消其transition,判断当前属于第几张图片,当为第零张图片的时候,将盒子迅速拉至复制出来的图片的第一张,当图片在最后一张的时候,将盒子迅速拉至未复制的图片的最后一张。
3.当手指滑屏时,改变其box的tranflateX.
4.当手指抬起时,得到处于第几张照片,然后将其滑入,并开启定时器。

var wrap = document.querySelector(".wrap");
var box = document.querySelector(".box");
box.innerHTML+=box.innerHTML;
var aLi = document.querySelectorAll(".box li");
var aNav = document.querySelectorAll("nav span");
var aHeight = aLi[0].offsetHeight;
var aWidth = wrap.offsetWidth;
wrap.style.height = aHeight + 'px';
box.style.width = aLi.length * 100 + "%";
for(var i=0;i<aLi.length;i++){
    aLi[i].style.width = 1/aLi.length * 100 + "%";
}
var startPoint = 0;
var startEle = 0;
var now = 0;
var timer = 0;
cssTransform(box,"translateX",0);
auto();
wrap.addEventListener("touchstart",function(e){
    clearInterval(timer);
    box.style.transition = "none";
    var moveX = cssTransform(box,"translateX");
    now = Math.round(-moveX/aWidth);
    if(now==0){
        now = aNav.length;
    }else if(now==aLi.length-1){
        now = aNav.length-1;
    }
    cssTransform(box,"translateX",-now*aWidth);
    startPoint = e.changedTouches[0].pageX;
    startEle = cssTransform(box,"translateX");
});
wrap.addEventListener("touchmove",function(e){
    var endPoint = e.changedTouches[0].pageX;
    var disX = endPoint - startPoint;
    cssTransform(box,"translateX",disX+startEle);
});
wrap.addEventListener("touchend",function(e){
    var moveX = cssTransform(box,"translateX");
    now = Math.round(-moveX/aWidth);
    tab();auto();
    
});
function auto(){
    clearInterval(timer);
    timer = setInterval(function(){
        if(now == aLi.length-1){
            now = aNav.length - 1;
        }
        box.style.transition = "none";
        cssTransform(box,"translateX",-now*aWidth);
        setTimeout(function(){
            now++;
            tab();
        },30);
    },2000);
};
function tab(){
    box.style.transition = ".5s";
    cssTransform(box,"translateX",-now*aWidth);
    for(var i=0;i<aNav.length;i++){
        aNav[i].className = "";
    };
    aNav[now%aNav.length].className = "active";
}

以上代码都放在:https://github.com/waterwong/swiper

相关文章

  • 使用原生JS实现移动端图片轮播效果(二)

    在上篇文章中,使用改变left的值实现轮播效果,在PC端上因为要兼容旧版浏览器,所以都采用这种做法。但是在移动端上...

  • 使用原生JS实现移动端图片轮播效果(一)

    PC端上实现图片轮播效果非常简单,只要通过使用click事件就可以非常简单的实现效果,但是在移动端上,就要通过核心...

  • 原生js实现图片轮播效果

    功能:实现图片每隔1秒切换一次;当鼠标停留在整个页面上,图片不进行轮播;鼠标移动到切换页选项上,出现该选项对应的图...

  • 循环当中的匿名函数问题

    前言:从《原生JS实现轮播(上)》中JS实现渐变效果引出的循环中匿名函数的问题。 如果匿名函数里使用了循环变量,或...

  • 小记setTimeout

    前言:从《原生JS实现轮播(上)》中JS实现渐变效果,引出的setTimeout用法问题。 对于setInterv...

  • 基于bootstrap.js的自适应轮播

    首先引入css,js文件 轮播代码 改造为移动端手势滑动 最终效果:

  • 一个移动端进度条

    简介 利用js原生写的一个移动端进度条 效果展示 代码实现 使用方式 1、引用使用 2、传入参数样例 3、注意事项...

  • 移动端网页特效

    移动端浏览器兼容性较好,不需要考虑以前JS的兼容性问题,可以放心的使用原生JS书写效果,但是移动端也有自己独特的地...

  • js原生实现移动端手指滑动轮播图效果

    html部分 css部分(使用了less) js部分 参考:https://blog.csdn.net/weixi...

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

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成。但是...

网友评论

    本文标题:使用原生JS实现移动端图片轮播效果(二)

    本文链接:https://www.haomeiwen.com/subject/sntcwttx.html