zoukankan      html  css  js  c++  java
  • javascript实现图片滚动

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

    首先看看 静态页的结构:

    <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>

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

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

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

    大体的布局就差不多了

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

    下面就是js代码:

    <!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>

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

  • 相关阅读:
    mysql 数据类型学习笔记(持续更新)
    datetime 和 timestamp 的区别
    Jupyter notebook 常用快捷键(持续更新)
    遍历SnoMed的multiHierarchy中给定概念的子概念
    Ramdom Walk with Restart
    矩阵和向量
    power-law
    一些SQL操作(收集)
    MySQL5.7.19-win64安装启动
    OO_UNIT1_SUMMARY
  • 原文地址:https://www.cnblogs.com/phpshen/p/3545073.html
Copyright © 2011-2022 走看看