首页 > Web开发 > 详细

javascript实现图片滚动

时间:2014-02-12 02:36:16      阅读:366      评论:0      收藏:0      [点我收藏+]

闲来无事捣鼓了一个原来的js图片滚动

首先看看 静态页的结构:

bubuko.com,布布扣
<body>
<a href="javascript: le()">向左</a>
<a href="javascript: re()">向右</a>
<div id="img">
<ul id="imgul">
<li><img src="img/1.jpg" height="150" width="200"/></li>
<li><img src="img/2.jpg" height="150" width="200" /></li>
<li><img src="img/3.jpg" height="150" width="200"/></li>
<li><img src="img/4.jpg" height="150" width="200"/></li>
</ul>
</div>
</body>
bubuko.com,布布扣

上面两个a标签 是控制图片滚动的走向

关键是div  ul  li  <img> 的结构      div里面是ul 人后是li 里面是图片img 标签

让li 有浮动 然后给 div 加一个左右外边距自动    在给 div 一个相对定位  ul一个绝对定位 

大体的布局就差不多了

滚动的大体思路就是,通过css定位和js定时器 改变ul 的left 属性 来实现滚动。

 

下面就是js代码:

bubuko.com,布布扣
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
*{
    padding:0px;
    margin:0px;
    }

li{
    height:150px;
    width:200px;
    float:left;
    margin:10px;
    }

ul{
    width:880px;
    height:170px;
    list-style-type: none;
    background-color:#FFF;
    position:absolute;
    left:0;
    top:0;

    }
    
div{
    width:880px;
    height:170px;
    margin-top:100px;
    margin-left:auto;
    margin-right:auto;
    background-color:#FF0000;
    position:relative;
    overflow:hidden;
    }


</style>
<script>
var f=-1;//新建一个全局变量
function le()//点击向左调用的方法
{
    f=-1;
    }
function re()//点击向右调用的方法
{
    f=1;
    }
window.onload=function (){
    odiv=document.getElementById(div);//获取div
    oul=document.getElementById(ul);//获取ul
    oul.innerHTML=oul.innerHTML+oul.innerHTML; //复制一份ul 里的内容
    oul.style.width=oul.offsetWidth*2+px;//应为ul 里的内容比原来多了一倍所以宽也要比原来多一倍
    
    
    //实现图片滚动的函数
    function cc (){
        //判断图片滚动的位置  向左时的情况
        if(oul.offsetLeft<-oul.offsetWidth/2)
        {            
            oul.style.left=0+px;
            }
            
                //判断图片滚动的位置  向右时的情况
                if(oul.offsetLeft>0)
        {            
            oul.style.left=-oul.offsetWidth/2+‘px‘;
            }
               //f为 上面的全局变量  为 正则是向右  为负则是向左
        oul.style.left=oul.offsetLeft+f+px;
        }
        //定时器
    var time=setInterval(cc,10);
     //鼠标移动到div上时 停止定时器
    odiv.onmouseover=function (){
            clearInterval(time);
            
            };
            //鼠标移出div时 在次运行定时器
    odiv.onmouseout=function (){
            time=setInterval(cc,10);
            
            };

    };
</script>
</head>

<body>
<a href="javascript: le()">向左</a>
<a href="javascript: re()">向右</a>
<div id="div">
 <ul id="ul">
   <li><img src="img/1.jpg" height="150"  width="200"/></li>
   <li><img src="img/2.jpg" height="150"  width="200" /></li>
   <li><img src="img/3.jpg" height="150"  width="200"/></li>
   <li><img src="img/4.jpg" height="150"  width="200"/></li>
 </ul>
</div>
</body>
</html>
bubuko.com,布布扣

 

大家如果有什么建议可以提出来!!谢谢!!

javascript实现图片滚动

原文:http://www.cnblogs.com/phpshen/p/3545073.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!