css实现带箭头和圆点的轮播

所属分类: 网页制作 / CSS 阅读数: 914
收藏 0 赞 0 分享

功能:图片轮播,当鼠标移入图片、圆点和方向键时,停止轮播,移除恢复。

1.首先建立div,并放入图片

#wai{

    width:300px;

    height: 300px;

    border: 1px solid red;

}   

img{

    width: 100%;

    height: 100%;

    display: none;

}
<div id="wai" onmouseover="qing()" onmouseout="hui()">

    <img src="timg.jpg"/style="display: block;">

    <img src="timg1.jpg"/>

    <img src="timg2.jpg"/>

    <img src="timg3.jpg"/>

</div>

2.添加4个圆点和左右方向

<!--四个点的div-->
<div id="dianbox">
	<div class="dian" style="border-color: green;" onclick="yuan(this,'0')" onmouseover="qing()" onmouseout="hui()">
	</div>
	<div class="dian" onclick="yuan(this,'1')" onmouseover="qing()" onmouseout="hui()">
	</div>
	<div class="dian" onclick="yuan(this,'2')" onmouseover="qing()" onmouseout="hui()">
	</div>
	<div class="dian" onclick="yuan(this,'3')" onmouseover="qing()" onmouseout="hui()">
	</div>	
</div>
<!--左箭头div-->
<div id="lbox" onclick="zuoyou(-1)" onmouseover="qing()" onmouseout="hui()">
	<br>
	<div id="l">
	</div>
</div>
<!--右箭头div-->
<div id="lbox" onclick="zuoyou(-1)" onmouseover="qing()" onmouseout="hui()">
	<br>
	<div id="l">
	</div>
</div>

3.写js

先定义计时器、写清除计时器函数和恢复计时器函数

定义计时器

var timer = setInterval("lun()",2000);

清除计时器函数

function qing(){

    window.clearInterval(timer);

}

恢复计时器函数

function hui(){

    timer = setInterval("lun()",2000);

}

写轮播函数并且换图时圆点变色

function lun(){ 

//  图片轮播

    bs++;

    var img = document.getElementsByTagName("img");

    if(bs>= img.length){

        bs=0;

    }

    for (i = 0;i<img.length;i++) {

        img[i].style.display="none";

    }

    img[bs].style.display="block";

//  圆点变色

    var dian = document.getElementsByClassName("dian");

    for (j = 0;j < img.length;j++) {

        dian[j].style.borderColor="red";

    }

    dian[bs].style.borderColor="green";

}

 鼠标点击圆点实现圆点变色并切换到相应图片 

//点圆换图清除定时器

    function yuan(x,y){

        bs=y;

        var img = document.getElementsByTagName("img");

        for(i = 0;i<img.length;i++){

            img[i].style.display="none";

        }

        img[y].style.display="block";

        var dian = document.getElementsByClassName("dian");

        for (j = 0;j<dian.length;j++) {

            dian[j].style.borderColor="red";

        }

        x.style.borderColor="green";

    }

鼠标点击方向实现切换到上一张或下一张图片并实现圆点的变化

function zuoyou(z){

    bs=bs+z;

    if(bs==4){

        bs=0;

    }

    if(bs<0){

        bs=3;

    }

    var img = document.getElementsByTagName("img");

    for(i = 0;i<img.length;i++){

        img[i].style.display="none";

    }

    img[bs].style.display="block";

    var dian = document.getElementsByClassName("dian");

    for (j=0;j<dian.length;j++) {

        dian[j].style.borderColor="red";

    }

    dian[bs].style.borderColor="green";

}

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多