JS简单封装的图片无缝滚动效果示例【测试可用】


Posted in Javascript onMarch 22, 2017

本文实例讲述了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" lang="utf-8">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无缝滚动图片示例-F-BLOG</title>
    <style type="text/css">
      ul{list-style:none;padding:0px;margin:0px;}
      #demo1 ul,#demo2 ul{width:400px;}
      #demo1 li,#demo2 li{float:left;}
    </style>
    <script type="text/javascript">
      function $(id){
        return document.getElementById(id);
      }
      function Marquee(id,toFollow,speed)
      {
        var doScroll;
        var scrollBox_x="<table cellpadding='0' cellspacing='0'><tr><td id='"+id+"abox'>"+$(id).innerHTML+"</td><td id='"+id+"bbox'>"+$(id).innerHTML+"</td></tr></table>";
        var scrollBox_y="<table cellpadding='0' cellspacing='0'><tr><td id='"+id+"abox'>"+$(id).innerHTML+"</td></tr><tr><td id='"+id+"bbox'>"+$(id).innerHTML+"</td></tr></table>";
        var begin=function(){
          switch(toFollow){
            case "left":
              $(id).innerHTML=scrollBox_x;
              doScroll=setInterval(function(){
                if($(id).scrollLeft==$(id+"abox").offsetWidth) $(id).scrollLeft=0;
                $(id).scrollLeft++;
              },speed);
              break;
            case "right":
              $(id).innerHTML=scrollBox_x;
              doScroll=setInterval(function(){
                if($(id).scrollLeft<=0) $(id).scrollLeft=$(id+"bbox").offsetWidth;
                $(id).scrollLeft--;
              },speed);
              break;
            case "top":
              $(id).innerHTML=scrollBox_y;
              doScroll=setInterval(function(){
                if($(id).scrollTop==$(id+"abox").offsetHeight) $(id).scrollTop=0;
                $(id).scrollTop++;
              },speed);
              break;
            case "bottom":
              $(id).innerHTML=scrollBox_y;
              doScroll=setInterval(function(){
                if($(id).scrollTop<=0) $(id).scrollTop=$(id+"bbox").offsetHeight;
                $(id).scrollTop--;
              },speed);
              break;
            }
          }
          begin();
          $(id).onmouseover=function() {clearInterval(doScroll);}
          $(id).onmouseout=function() {begin();}
        }
        window.onload=function(){
          Marquee("demo2","left",30);
          Marquee("demo1","right",20);
          Marquee("demo3","top",30);
          Marquee("demo4","bottom",30);
        }
</script>
  </head>
<body>
   <div id="demo1" style="overflow:hidden;height:100px;width:300px;">
     <ul>
       <li><img src="mm.jpg" mce_src="mm.jpg" style="height:100px;width:200px;" /></li>
       <li><img src="me.jpg" mce_src="me.jpg" style="height:100px;width:200px;" /></li>
     </ul>
   </div>
   <br/>
   <div id="demo2" style="overflow:hidden;height:100px;width:300px;">
     <ul>
       <li><img src="mm.jpg" mce_src="mm.jpg" style="height:100px;width:200px;" /></li>
       <li><img src="me.jpg" mce_src="me.jpg" style="height:100px;width:200px;" /></li>
     </ul>
   </div>
   <br/>
   <div id="demo3" style="overflow:hidden;height:150px;width:200px;">
     <ul>
       <li><img src="mm.jpg" mce_src="mm.jpg" style="height:100px;width:200px;" /></li>
       <li><img src="me.jpg" mce_src="me.jpg" style="height:100px;width:200px;" /></li>
     </ul>
   </div>
   <br/>
   <div id="demo4" style="overflow:hidden;height:150px;width:200px;">
     <ul>
       <li><img src="mm.jpg" mce_src="mm.jpg" style="height:100px;width:200px;" /></li>
       <li><img src="me.jpg" mce_src="me.jpg" style="height:100px;width:200px;" /></li>
     </ul>
   </div>
</body>
</html>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
表单填写时用回车代替TAB的实现方法
Oct 09 Javascript
动态创建样式表在各浏览器中的差异测试代码
Sep 13 Javascript
jquery实现文字由下到上循环滚动的实例代码
Aug 09 Javascript
jQuery实现倒计时按钮功能代码分享
Sep 03 Javascript
探寻Javascript执行效率问题
Nov 12 Javascript
12个超实用的JQuery代码片段
Nov 02 Javascript
Markdown+Bootstrap图片自适应属性详解
May 21 Javascript
Backbone中View之间传值的学习心得
Aug 09 Javascript
JS仿hao123导航页面图片轮播效果
Sep 01 Javascript
Vue中render方法的使用详解
Jan 26 Javascript
Vue实现手机计算器
Aug 17 Javascript
vue.js 输入框输入值自动过滤特殊字符替换中问标点操作
Aug 31 Javascript
Vue计算属性的学习笔记
Mar 22 #Javascript
Angular2实现自定义双向绑定属性
Mar 22 #Javascript
Bootstrap如何激活导航状态
Mar 22 #Javascript
Bootstrap超大屏幕的实现代码
Mar 22 #Javascript
Bootstrap缩略图的创建方法
Mar 22 #Javascript
JS+DIV实现的卷帘效果示例
Mar 22 #Javascript
Bootstrap页面标题Page Header的实现方法
Mar 22 #Javascript
You might like
使用Smarty 获取当前日期时间和格式化日期时间的方法详解
2013/06/18 PHP
解析在PHP中使用全局变量的几种方法
2013/06/24 PHP
php中的Base62类(适用于数值转字符串)
2013/08/12 PHP
PHP获取当前页面URL函数实例
2014/10/22 PHP
Laravel框架实现多个视图共享相同数据的方法详解
2019/07/09 PHP
Javascript的IE和Firefox兼容性汇编(zz)
2007/02/02 Javascript
用方法封装javascript的new操作符(一)
2010/12/25 Javascript
javascript动态加载实现方法一
2012/08/22 Javascript
21个JavaScript事件(Events)属性汇总
2014/12/02 Javascript
js+CSS实现弹出居中背景半透明div层的方法
2015/02/26 Javascript
jQuery简单实现图片预加载
2015/04/20 Javascript
JS动态计算移动端rem的解决方案
2016/10/14 Javascript
10个最优秀的Node.js MVC框架
2017/08/24 Javascript
bootstrap响应式工具使用详解
2017/11/29 Javascript
Node.js成为Web应用开发最佳选择的原因
2018/02/05 Javascript
Node.js引入UIBootstrap的方法示例
2018/05/11 Javascript
Postman的下载及安装教程详解
2018/10/16 Javascript
layui动态渲染生成select的option值方法
2019/09/23 Javascript
vue中的计算属性和侦听属性
2020/11/06 Javascript
[01:35]2018年度CS GO最佳战队-完美盛典
2018/12/17 DOTA
Python的批量远程管理和部署工具Fabric用法实例
2015/01/23 Python
python3.5仿微软计算器程序
2020/03/30 Python
pycharm安装和首次使用教程
2018/08/27 Python
python实现弹窗祝福效果
2019/04/07 Python
python3实现二叉树的遍历与递归算法解析(小结)
2019/07/03 Python
python 使用递归实现打印一个数字的每一位示例
2020/02/27 Python
如何Tkinter模块编写Python图形界面
2020/10/14 Python
python 利用openpyxl读取Excel表格中指定的行或列教程
2021/02/06 Python
最新党员思想汇报
2014/01/01 职场文书
给老师的检讨书
2014/02/11 职场文书
安全生产活动月方案
2014/03/09 职场文书
中班幼儿评语大全
2014/04/30 职场文书
画展观后感
2015/06/17 职场文书
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
2021/04/05 MySQL
Python opencv缺陷检测的实现及问题解决
2021/04/24 Python
Spring Data JPA框架持久化存储数据到数据库
2022/04/28 Java/Android