轮播图

做了一个简易版的轮播图,html结构拿了网上的一个人的例子,然后重新写css和js部分。
大概实现的功能如下

  • 能够实现图片按照时间轮流播放
  • 自动生成页脚的数字标示,并且鼠标点击就可以生成新的轮播图
  • 只要更改.banner_list里面的链接数量,就能生成新的轮播图

对原来的代码的改进之处,话说原来的代码的几个槽点

  • 无一例外用id,id的使用这样样式不能重现,最外侧用id做标示,内部用class复用率高
  • 用setTimeout来做动画,透明度其实用transition就好了

还可以的改进之处

  • 图片懒加载
  • 做成组件

代码清单,有机会做成组件吧

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        #banner{
            height: 286px;
            width:478px;
            overflow:hidden;
            position: relative;
        }
        .banner_list .active{
            z-index: 1;!important;
            opacity: 1;
        }
        .banner_list a{
            position: absolute;
            top:0;
            z-index: 0;
            opacity: 0;
            transition: opacity 1s;
        }
        .list{
            position: absolute;
            z-index: 99;
            display: flex;
            list-style-type: none;
            justify-content: space-between;
            bottom: 10px;
            right: 20px;

        }
        .list li {
            width: 15px;
            height: 15px;
            background-color: beige;
            border-radius: 50%;
            padding-left: 6px;
            padding-bottom: 6px;
            margin-right: 10px;
        }
    </style>
</head>
<body>
<div id="banner">
    <div class="banner_bg"></div>  <!--标题背景-->
    <a href="#" class="banner_info"></a> <!--标题-->
    <ul class="list"></ul>
    <div class="banner_list">
        <a href="#" target="_blank"><img src="imgs/p1.jpg" title="橡树小屋的blog1" alt="橡树小屋的blog" /></a>
        <a href="#" target="_blank"><img src="imgs/p5.jpg" title="橡树小屋的blog2" alt="橡树小屋的blog" /></a>
        <a href="#" target="_blank"><img src="imgs/p3.jpg" title="橡树小屋的blog3" alt="橡树小屋的blog" /></a>
        <a href="#" target="_blank"><img src="imgs/p4.jpg" title="橡树小屋的blog4" alt="橡树小屋的blog" /></a>
    </div>
</div>
<script>
    var sliceBox = (function(){
        var list_dom = null;    //链接的container
        var container = null;   //轮播图的主题
        var list = null;    //这个dom标示图片的按钮
        var img_list = [];
        var c_list = [];

        var cur_num = 0;
        var pic_num = 0;

        var timer = null;
        var duration = 1000;

        function changePic(){
            img_list[cur_num].classList.remove("active");
            cur_num = (cur_num+1)%pic_num;
            img_list[cur_num].classList.add("active");
            timer = setTimeout(changePic,duration);
        }

        function init(selector,duration_time){
            duration = duration_time;
            container = document.querySelector(selector);
            list_dom = container.querySelector(selector+" .banner_list");
            pic_num = list_dom.childElementCount;
            img_list = Array.prototype.slice.call(list_dom.children);
            img_list[0].classList.add("active");
            timer = setTimeout(changePic,duration);
            addButton(selector);
        }

        function addButton(selector){

            list = document.querySelector(selector+" .list");
            for(var i=0;i<pic_num;i++){
                var li = document.createElement("li");
                c_list.push(li);
                li.textContent = i+1;
                li.onclick = function(e){
                    clearTimeout(timer);
                    img_list[cur_num].classList.remove("active");
                    cur_num = parseInt(e.target.textContent)-1;
                    img_list[cur_num].classList.add("active");
                    timer = setTimeout(changePic,duration);
                };
                list.appendChild(li);
            }
        }

        return {
            init:init
        }
    })();
    sliceBox.init("#banner",2000);

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

推荐阅读更多精彩内容