Javascript专题(三)a.各种轮播和细节分析-------淡入淡出的轮播方式(非面向对象版本)

这次我们来探讨一下关于各种轮播函数以及各种相关css的细节。我按照书写过程中出的预想偏差来写。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    div,ul,li{
        margin:0;
        padding:0;
        list-style: none;
        border: 0;
    }
    body{
        background: #f0f8ff;
    }
    #box{
        margin:10px auto;
        position: relative;
        /*position内容,relative和absolute自行学习!!!!!!!absolute很重要*/
        width: 502px;
        height: 202px;
        /*此处多的两个边框属性用于.list-image的border*/
        cursor: pointer;
        border: 8px solid #fff;
    }
    .list-image{
        width: 500px;
        height: 200px;
        border: 1px solid purple;
        position: relative;
    }
    .list-image li{
/*      width: 500px;
        height: 200px;*/
        /*font-size: 0;*/

    }
    </style>
</head>
<body>
    <div id="box">
        <ul class="list-image">
            <li class="current">![](../image/landscape_map/047.jpg)</li>
            <li>![](../image/landscape_map/041.jpg)</li>
            <li>![](../image/landscape_map/042.jpg)</li>
            <li>![](../image/landscape_map/043.jpg)</li>
            <li>![](../image/landscape_map/037.jpg)</li>
        </ul>
        <ul class="list-number">
            <li class="current">1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
        </ul>
    </div>
</body>
<script type="text/javascript">
    var oBox=document.getElementById("box");
    var oUl=oBox.getElementsByTagName("ul");
    var oImage=oUl[0].getElementsByTagName("li");

</script>
</html>


问题来了,我明明在开头加了margin:0,padding:0,这个时候的li之间为什么还是会有白色边距????我们来加一句话:

        alert(oImage[1].offsetHeight);//输出203

也就是说,我的图片虽然设置的是200px的高度,但是li的高度确是203px,而我们在开头给li设置的margin:0,padding:0也没有生效!!

那么解决方法是什么呢?上方代码中注释的font-size:0和直接给li设置width:500和height:200均可以解决这个问题。答主能力有限,暂时无法说明为什么。

接下来我往.list-image上加了一句话。

    .list-image{
        width: 500px;
        height: 200px;
        border: 1px solid purple;
        position: relative;
        overflow: hidden;
    }

超过边界的东西都直接被隐藏了起来,之后我加上了这么一句.

    .list-image li{
        width: 500px;
        height: 200px;
        position: absolute;
    }

它变成了这样:

即是说,一个position:absolute改变了这么多。这又是为什么呢?

后来居上
如果有多个元素在同一位置设置了position:absolute的话,当然这种清况是很少见的,这种情况会遵循浏览器的渲染顺序表现,也就是后来者居上的意思。
position之absolute定位深入理解

之后我们再写

    .list-image li{
        width: 500px;
        height: 200px;
        position: absolute;
        opacity: 0;
        filter: alpha(opacity=0);
    }
    .list-image li.current{
        opacity: 1;
        filter: alpha(opacity=1);
        /*filter是兼容写法,兼容IE8以下的*/
    }

又回到了正确的状态。(其实本人也不是很懂,先留坑,待更)

  • opacity=0,该元素隐藏起来了,但不会改变页面布局,并且,如果该元素已经绑定一些事件,如click事件,那么点击该区域,也能触发点击事件的
  • visibility=hidden,该元素隐藏起来了,但不会改变页面布局,但是不会触发该元素已经绑定的事件
  • display=none,把元素隐藏起来,并且会改变页面布局,可以理解成在页面中把该元素删除掉一样

接下来修改样式。

    .list-number li{
        float: left;
        color: #fff;
        background: #f60;
        width: 20px;
        height: 20px;
        border-radius: 20px;
        cursor: pointer;
        margin-right: 5px;
        text-align: center;
        font:10px/20px Arial;
        opacity: 0.7;
        filter: alpha(opacity=70);
    }
    .list-number li.current{
        opacity: 1;
        filter: alpha(opacity=100);
    }

至此,基本布局完成,接下来我们用JS实现淡入淡出的轮播效果。


接下来,我们先实现普通的图片切换。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    div,ul,li{
        margin:0;
        padding:0;
        list-style: none;
        border: 0;
    }
    body{
        background: #f0f8ff;
    }
    #box{
        margin:10px auto;
        position: relative;
        /*position内容,relative和absolute自行学习!!!!!!!absolute很重要*/
        width: 502px;
        height: 202px;
        /*此处多的两个边框属性用于.list-image的border*/
        border: 8px solid #fff;
    }
    .list-image{
        width: 500px;
        height: 200px;
        border: 1px solid purple;
        position: relative;
        overflow: hidden;
    }
    .list-image li{
        width: 500px;
        height: 200px;
        position: absolute;
        opacity: 0;
        filter: alpha(opacity=0);
    }
    .list-image li.current{
        opacity: 1;
        filter: alpha(opacity=100);
        /*filter是兼容写法,兼容IE8以下的*/
    }


    .list-number{
        position: absolute;
        right: 0;
        bottom: 5px;
    }
    .list-number li{
        float: left;
        color: #fff;
        background: #f60;
        width: 20px;
        height: 20px;
        border-radius: 20px;
        cursor: pointer;
        margin-right: 5px;
        text-align: center;
        font:10px/20px Arial;
        opacity: 0.7;
        filter: alpha(opacity=70);
    }
    .list-number li.current{
        opacity: 1;
        filter: alpha(opacity=100);
    }
    </style>
</head>
<body>
    <div id="box">
        <ul class="list-image">
            <li class="current">![](../image/landscape_map/047.jpg)</li>
            <li>![](../image/landscape_map/041.jpg)</li>
            <li>![](../image/landscape_map/042.jpg)</li>
            <li>![](../image/landscape_map/043.jpg)</li>
            <li>![](../image/landscape_map/037.jpg)</li>
        </ul>
        <ul class="list-number">
            <li class="current">1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
        </ul>
    </div>
</body>
<script type="text/javascript">
    var oBox=document.getElementById("box");
    var oUl=oBox.getElementsByTagName("ul");
    var oImage=oUl[0].getElementsByTagName("li");
    var oNumber=oUl[1].getElementsByTagName("li");
    var index=0;

    for(var i=0;i<oNumber.length;i++){
        oNumber[i].index=i;
        oNumber[i].onmouseover=function(){
            show(this.index);
        }
    }

    function show(x){
        for(var i=0;i<oNumber.length;i++){
            oNumber[i].className="";
            oImage[i].className="";
        }
        oNumber[x].className="current";
        oImage[x].className="current";
    }
</script>
</html>

我们在JS中直接使用了current样式,因此切换的特别突兀,所以我们在这里进行修改使它变成淡入淡出的。
首先,我们添加全局变量 var timer=null;接下来,修改show(x)函数


    function show(x){
        for(var i=0;i<oNumber.length;i++){
            oNumber[i].className="";
            // oImage[i].className="";
            //我们发现以上的""的css元素已经被我们改变,因此这种方法不行。
            oImage[i].style["opacity"]=0;
            //上面这句等同于 oImage[i].style.opacity=0;
            oImage[i].style.filter="alpha(opacity=0)";

        }
        oNumber[x].className="current";
        // oImage[x].className="current";
        //注释掉上方,开始我们不突兀的淡入淡出轮播

        var alpha=0;
        //变量记录透明度变化(淡入淡出实现的根本)
        clearInterval(timer);
        //停止计时器,自行体会,主要用于切换之中
        timer=setInterval(function(){
            alpha+=2;
            alpha>100  &&  (alpha=100);
            oImage[x].style.opacity=alpha/100;
            alpha==100 && clearInterval(timer);
        },20);
    }  

之后,我们来实现自动的淡入淡出轮播。首先,我们添加自动计时器。
var play_timer=null;
接着,添加记录当前第几章图片的index。
var index=0;
同时,我们要在show(x)最后一句上加个
index=x;消除某些bug。
然后添加自动函数。

oBox.onmouseover=function(){
        clearInterval(play_timer);
    }
    function Auto(){
        play_timer=setInterval(function(){
            if(index<oNumber.length-1){
                index++;
            }else{
                index=0;
            }

            show(index);
        },2000);
    }
    oBox.onmouseout=function(){
        Auto();
    }
    Auto();

淡入淡出轮播源码地址 github

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,748评论 1 92
  • 首先先看demo吧,点击查看demo 一、随便说几句 css3动画效果的强大不言而喻,自它出现一直热度不减,它与j...
    忽如寄阅读 51,317评论 17 55
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,061评论 25 707
  • 这一次,我们用原生JS实现上下滚动方式的轮播。 首先,我们来学习一下如何用JS创建HTML元素。 值得注意的是上方...
    海客无心阅读 667评论 0 1
  • 最近正在读朋友送给我的一本书——《自在独行》。直到现在,都一直把这份孤独的惊喜藏着掖着,生怕独行的我拿出手后,让人...
    马道子阅读 426评论 0 4