轮播图

作者: 进击的前端 | 来源:发表于2016-10-05 14:49 被阅读37次

做了一个简易版的轮播图,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>

相关文章

  • 无标题文章

    轮播图分为:传统轮播图、间歇轮播图、呼吸轮播图、无缝滚动轮播图等。它们各具特色,各有用处。 1.传统轮播图 第一步...

  • 轮播图

    轮播图分为:传统轮播图、间歇轮播图、呼吸轮播图、无缝滚动轮播图等。 1.传统轮播图 第一步,得到元素 第二步,设置...

  • 现金红包

    每日红包 轮播图 详情图 周末红包 轮播图 详情图 圣诞红包 轮播图 详情图

  • day7_作业

    轮播图1 轮播图2

  • [iOS]定制性强的广告轮播图--SCAdView

    @[无限轮播图] @[3D轮播图] @[广告轮播图] SCAdView Statement If my code ...

  • 普通奖品

    卡西欧小方块 轮播图 详情图 三只松鼠大礼包 轮播图 详情图 天猫精灵 轮播图 详情图 小米蓝牙无线耳机 轮播图 ...

  • 轮播图心得

    轮播图 写轮播图之前我们要认识到几个问题:一、什么是轮播图?二、怎么实现轮播效果?三、轮播图还有什么小功能可以实现...

  • 第五周学习内容

    焦点图轮播特效之原理、焦点图轮播样式之布局、焦点图轮播之箭头切换、焦点图轮播之无限滚动。 js简介、用法、输出。

  • 三种样式的轮播图

    一、100%比例轮播图 HTML代码 CSS样式 js代码 二、手动箭头轮播图 三、简易轮播图

  • 多轮播图的设计

    列表展示多个轮播图 多个轮播图同时显示 多个轮播图不定时进行轮播动画 对应呈现的关系:1个TableView、一个...

网友评论

      本文标题:轮播图

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