自适应左右滑动切换轮播

前端入坑纪 33

挖坑了,最近忙着写html5的小游戏,少了更新。

这会儿,乘着有空,稍微更新一个先前的轮播效果。

闲言少叙,直入正题。

又是一个轮播

OK,first things first!项目链接

HTML 结构
<div class="swipWrp">
    <div id="swiper" class="clear">
        ![](http://upload-images.jianshu.io/upload_images/4732938-8206bfad17390bb8.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        ![](http://upload-images.jianshu.io/upload_images/4732938-3f4267d10670065a.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        ![](http://upload-images.jianshu.io/upload_images/4732938-98b2e3cb7fc5798d.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        ![](http://upload-images.jianshu.io/upload_images/4732938-90a0b25e3a601454.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
    </div>
</div>

依旧简洁的div#swiper 宽度为400%(100%*4)包裹图片,让图片向左浮动,并且宽度为25%(100%/4)。而div.swipWrp是用来定位轮播里的小圆点的(代码里生成)

CSS 结构
        body {
            padding: 0;
            margin: 0;
            background-color: #F4F4F4;
        }
        
        p {
            padding: 0;
            margin: 0;
        }
        
        ul,
        li {
            padding: 0;
            margin: 0;
            list-style: none;
        }
        
        a {
            text-decoration: none;
            color: #525252;
        }
        
        img {
            vertical-align: middle;
        }
        
        .fl {
            float: left;
        }
        
        .fr {
            float: right;
        }
        
        .clear::after {
            display: block;
            content: "";
            clear: both;
        }

    .swipWrp {
            position: relative;
            width: 100%;
            margin: 0 auto;
            overflow: hidden;
            
        }
        
        #swiper {
            width: 400%;
            position: relative;
            overflow: hidden;
            text-align: center;
            transition: all 400ms ease-in;
            background-color: #ededed;
        }
        
        #swiper img {
            float: left;
            margin: 0 auto;
            width: 25%;
        }
        
        #tags {
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100%;
            text-align: center;
        }
        
        #tags a {
            display: inline-block;
            transition: all 1s ease;
            width: 9px;
            height: 9px;
            margin: 3px 6px;
            border-radius: 4.5px;
            background-color: rgba(255, 255, 255, .5)
        }
        
        #tags a.on {
            transform: scale(1.2, 1.2);
            background-color: rgba(255, 255, 255, .85)
        }

轮播里的图片和小圆点切换都加了过渡动画。至于从css开始到.clear类的那些都是重置样式,基本我的项目里都有。小伙伴应该很熟悉了。

JS 结构
                var swiper = document.getElementById("swiper");// 获取轮播本身
                var imgs = swiper.getElementsByTagName("img");// 获取轮播里的图片
                var indx = 0;// 轮播变换的顺序id
                var timers = null;// 最开始设定存放计时器的变量

                                // 这里开始就是创建切换轮播时的小圆点
                var nodeFgmt = document.createDocumentFragment();// 创建个文档片段,存放接下来生产的html文档
                newNode = document.createElement("div");// 创建个div
                newNode.id = "tags";// 给新的div一个id

                                // 根据图片数创建相应数量的a标签
                for(var i = 0; i < imgs.length; i++) {
                    var ond = document.createElement("a");
                    ond.href = "javascript:;";
                    ond.setAttribute("data-indx", i);// 给每个a设置自定义属性“data-indx”
                    nodeFgmt.appendChild(ond);// 把所有的a加到之前创建的文档片段里
                }
                newNode.appendChild(nodeFgmt);// 把文档片段加到前面创建的div里

                swiper.parentNode.appendChild(newNode);// 给轮播的父级添加上面创建好的div#tags
                                
                                 
                var tagsA = document.getElementById("tags").getElementsByTagName("a");// 创建完就获取里面的a吧

                                // 给a添加事件和切换的效果
                for(var s = 0; s < tagsA.length; s++) {
                    tagsA[s].onmouseover = function() {
                        offEft();
                        hideAll();
                        var indxA = this.getAttribute("data-indx");
                        changeEffect(indxA);
                        this.className = "on"
                    }
                    tagsA[s].onmouseout = function() {
                        onEft();
                    }
                }

                                // 默认第一个a为选中
                tagsA[0].className = "on";


                                // 重置所有a的class为空,也就是都未不选中状态
                function hideAll() {
                    for(var i = 0; i < imgs.length; i++) {
                        tagsA[i].className = ""
                    }
                }

                                // 调用轮播效果的代码
                function scrollIntvel() {
                    timers = setInterval(function() {
                        hideAll()
                        if(indx < imgs.length - 1) {
                            indx++;
                        } else {
                            indx = 0;
                        }
                        changeEffect(indx);
                    }, 3600);
                }

                               // 轮播切换时的代码
                function changeEffect(indx) {

                    swiper.style.transform = "translateX(-" + 25 * indx + "%)";
                    tagsA[indx].className = "on";

                }
                                
                              // 开启效果
                function onEft() {
                    scrollIntvel()
                }

                              // 关闭效果
                function offEft() {
                    clearInterval(timers);
                }

                                
                scrollIntvel()  // 运行调用轮播效果

                               // 左滑时的要执行的效果
                function swiperLeft() {
                    hideAll();
                    if(indx > 0) {
                        indx--;
                    } else {
                        indx = imgs.length - 1;
                    }
                    changeEffect(indx);
                }


                                 // 右滑时的要执行的效果
                function swiperRight() {
                    hideAll();
                    if(indx < imgs.length - 1) {
                        indx++;
                    } else {
                        indx = 0;
                    }
                    changeEffect(indx);
                }


                                 // 判断左滑,还是右滑,并执行对应效果

                var startX = endX = 0; // 先定义个存放x轴上的开始位置和结束位置的变量

                                 // 获取开始触摸时x轴位置,并停止自动轮播的效果
                swiper.addEventListener("touchstart", function(evt) {
                    startX =endX =  evt.targetTouches[0].clientX;
                    offEft();
                });

                                 // 获取触摸过程中x轴位置
                swiper.addEventListener("touchmove", function(evt) {
                    endX = evt.targetTouches[0].clientX;
                });

                                 // 滑动结束时判断方向,执行对应效果,并开启自动轮播的效果
        swiper.addEventListener("touchend", function(evt) {
            if (endX - startX < -47) {
                swiperRight()
            } else if (endX - startX > 47) {
                swiperLeft()
            }
            onEft()
        });

因为是挖坑,所以这次代码备注的也特别详细,不然感觉对不起小伙伴。那么有兴趣的同学,可以好好研究一翻,期待你我共同进步!!!

好了,到此,本文告一段落!感谢您的阅读!祝你身体健康,阖家幸福!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,302评论 5 470
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,232评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,337评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,977评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,920评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,194评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,638评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,319评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,455评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,379评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,426评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,106评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,696评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,786评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,996评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,467评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,043评论 2 341

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,722评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,280评论 25 707
  • 之前网上有很多PhpStorm在线激活地址,但是基本上大多数都被封杀。其他激活方式又行不通(有知道的可以分享下),...
    794f64d7a292阅读 9,802评论 0 0
  • 首先简单的介绍下什么是淘宝客,淘宝客呢就是帮淘宝店铺推广商品的一群人,淘宝店主想要提高销量,增加商品权重, 会设置...
    大鱼洋洋阅读 364评论 0 1
  • 这里要分享的是我自己的真实故事。 大二的时候,同学拉我去听讲座,认识了前排坐的一个学姐,这位学姐在课间非常...
    淙音阅读 1,095评论 13 26