再次更新!MSClass (Class Of Marquee Scroll通用不间断滚动JS封装类 Ver 1.6)


Posted in Javascript onFebruary 05, 2007

再次更新!MSClass (Class Of Marquee Scroll通用不间断滚动JS封装类 Ver 1.6)

/*MSClass (Class Of Marquee Scroll通用不间断滚动JS封装类) Ver 1.6*\

 制作时间:2006-08-29 (Ver 0.5)
 发布时间:2006-08-31 (Ver 0.8)
 更新时间:2007-01-31 (Ver 1.6)
 更新说明: + 加入功能 * 修正、完善
        1.6.070131
                + 禁止鼠标控制暂停或继续 (将第9个参数设置为-1或者动态赋值将ScrollSetp设置为-1)
                + 判断是否可以滚动 (若内容区域小于显示区域,则自动取消滚动)
                + 跳过初始化错误 (避免引起其它滚动的停止)
                + 默认值 (除容器ID必选外,其他参数均可根据情况进行选择设置)
                + 参数动态赋值 (方向可用英文表示top|bottom|left|right,使其更直观、方便)
                * 文字滚动不准确 (本次更新主要目的解决此Bug,感谢周?参与测试)
        1.4.061211
                + 鼠标悬停改变滚动方向 (鼠标悬停控制左右滚动)
                * 由于文档下载过慢而导致获取的高度/宽度不准确
                * 浏览器兼容问题 (IE、FF、Opera、NS、MYIE)
        1.2.060922
                + 指定范围间歇滚动
                * 程序调整
                * 连续间歇滚动停止的错误
        1.0.060901
                + 向下、向右滚动
                + 开始等待时间
                + 连续滚动
                * 调整时间单位
                * 滚动误差
                * 随机死循环
                * 加强性能
                * 程序优化
        0.8.060829
                  翻屏不间断向上、向左滚动

 演示地址:http://www.popub.net/script/MSClass.html
 下载地址:http://www.popub.net/script/MSClass.js

 应用说明:页面包含<script type="text/javascript" src="MSClass.js"></script>

        创建实例:
                //参数直接赋值法
                new Marquee("marquee")
                new Marquee("marquee","top")
                ......
                new Marquee("marquee",0,1,760,52)
                new Marquee("marquee","top",1,760,52,50,5000)
                ......
                new Marquee("marquee",0,1,760,104,50,5000,3000,52)
                new Marquee("marquee",null,null,760,104,null,5000,null,-1)

                //参数动态赋值法
                var marquee1 = new Marquee("marquee")        *此参数必选
                marquee1.Direction = "top";        或者        marquee1.Direction = 0;
                marquee1.Step = 1;
                marquee1.Width = 760;
                marquee1.Height = 52;
                marquee1.Timer = 50;
                marquee1.DelayTime = 5000;
                marquee1.WaitTime = 3000;
                marquee1.ScrollStep = 52;
                marquee1.Start();

        参数说明:
                ID                "marquee"        容器ID                (必选)
                Direction        (0)                滚动方向        (可选,默认为0向上滚动) 可设置的值包括:0,1,2,3,"top","bottom","left","right" (0向上 1向下 2向左 3向右)
                Step                (1)                滚动的步长        (可选,默认值为2,数值越大,滚动越快)
                Width                (760)                容器可视宽度        (可选,默认值为容器初始设置的宽度)
                Height                (52)                容器可视高度        (可选,默认值为容器初始设置的高度)
                Timer                (50)                定时器                (可选,默认值为30,数值越小,滚动的速度越快,1000=1秒,建议不小于20)
                DelayTime        (5000)                间歇停顿延迟时间(可选,默认为0不停顿,1000=1秒)
                WaitTime        (3000)                开始时的等待时间(可选,默认或0为不等待,1000=1秒)
                ScrollStep        (52)                间歇滚动间距        (可选,默认为翻屏宽/高度,该数值与延迟均为0则为鼠标悬停控制,-1禁止鼠标控制)
 使用建议:
                1、建议直接赋予容器的显示区域的宽度和高度,如(<div id="marquee" style="width:760px;height:52px;">......</div>)
                2、建议为容器添加样式overflow = auto,如(<div id="marquee" style="width:760px;height:52px;overflow:auto;">......</div>)
                3、为了更准确的获取滚动区域的宽度和高度,请尽可能将各滚动单位直接赋予正确宽高度
                4、对于TABLE标记的横向滚动,需要对TABLE添加样式display = inline,如(<div id="marquee" style="width:760px;height:52px;overflow:auto;"><table style="display:inline">......</table></div>)
                5、对于翻屏滚动或间歇滚动,要注意各滚动单位间的间距,同时需要对容器的可视高度和可视宽度做好准确的设置,对于各滚动单位间的间距可以通过设置行间距或者单元格的高宽度来进行调整
                6、对于LI自动换行的问题暂时没有更好的解决办法,建议将其转换成表格(TABLE)的形式来达到同等的效果
                7、针对横向滚动的文字段落,如果最末端是以空格" "结束的,请将空格" "转换成" "
                8、鼠标悬停滚动思想源自Flash,所以有一定的局限性(容器内仅允许用图片<img>或者带链接的图片<a><img></a>的形式,并需要禁止其自动换行)

 感

谢:
        周? zhoujun#yuchengtech.com (文字滚动跳行的bug) 2007/01/31
        自本程序发布以来,收到不少朋友的邮件,提出了很多意见和建议,感谢大家的支持!
很不错。

不过演示代码的new Marquee("marquee",0,1,760,52,50,5000,3000)那么多参数看了让人有点迷糊,呵呵,做成这种模式可能让人看得懂一些:

function Marquee()  
{  
    this.ID = document.getElementById(arguments[0]);  
    this.Direction = arguments[1];  
    this.Step = arguments[2];  
    this.Width = arguments[3];  
    this.Height = arguments[4];  
    this.Timer = arguments[5];  
    this.WaitTime = arguments[6];  
    this.StopTime = arguments[7];  
    this.CTL = this.StartID = this.Stop = this.MouseOver = 0;  
    this.ID.style.overflowX = this.ID.style.overflowY = "hidden";  
    this.ID.noWrap = true;  
    this.ID.style.width = this.Width;  
    this.ID.style.height = this.Height;  
    this.ID.innerHTML += this.ID.innerHTML;  
}  

然后使用:

var m = new Marquee;  
m.ID = document.getElementById("marquee");  
m.Direction = 0;  
m.Step = 1;  
m.Width = 760;  
// ......  
m.Start(m, m.Timer, m.WaitTime, m.StopTime); 

m.Start的参数好像都和m有关,可以省略掉?
Javascript 相关文章推荐
JQuery对checkbox操作 (循环获取)
May 20 Javascript
js 立即调用的函数表达式如何写
Jan 12 Javascript
JavaScript继承基础讲解(原型链、借用构造函数、混合模式、原型式继承、寄生式继承、寄生组合式继承)
Aug 16 Javascript
轻松实现jquery手风琴效果
Jan 14 Javascript
JavaScript简单拖拽效果(1)
May 17 Javascript
Iscrool下拉刷新功能实现方法(推荐)
Jun 26 Javascript
Vue 实现双向绑定的四种方法
Mar 16 Javascript
vue-cli2打包前和打包后的css前缀不一致的问题解决
Aug 24 Javascript
js中Array对象的常用遍历方法详解
Jan 17 Javascript
element-ui如何防止重复提交的方法步骤
Dec 09 Javascript
vue实现广告栏上下滚动效果
Nov 26 Vue.js
如何理解Vue简单状态管理之store模式
May 15 Vue.js
js滚动条多种样式,推荐
Feb 05 #Javascript
如何在标题栏显示框架内页面的标题
Feb 03 #Javascript
张孝祥JavaScript学习阶段性总结(2)--(X)HTML学习
Feb 03 #Javascript
使用JS操作页面表格,元素的一些技巧
Feb 02 #Javascript
JavaScript使用cookie
Feb 02 #Javascript
如何判断图片地址是否失效
Feb 02 #Javascript
Javascript的IE和Firefox兼容性汇编(zz)
Feb 02 #Javascript
You might like
使用php实现下载生成某链接快捷方式的解决方法
2013/05/07 PHP
php中return的用法实例分析
2015/02/28 PHP
php实现数组按指定KEY排序的方法
2015/03/30 PHP
PHP记录和读取JSON格式日志文件
2016/07/07 PHP
php观察者模式应用场景实例详解
2017/02/03 PHP
php检查函数必传参数是否存在的实例详解
2017/08/28 PHP
Laravel使用Queue队列的技巧汇总
2019/09/02 PHP
javascript 学习之旅 (1)
2009/02/05 Javascript
将jQuery应用于login页面的问题及解决
2009/10/17 Javascript
javascript css styleFloat和cssFloat
2010/03/15 Javascript
网站404页面3秒后跳到首页的实例代码
2013/08/16 Javascript
javascript实现图片跟随鼠标移动效果的方法
2015/05/13 Javascript
基于jQuery实现的扇形定时器附源码下载
2015/10/20 Javascript
js本地图片预览实现代码
2016/10/09 Javascript
Ionic项目中Native Camera的使用方法
2017/06/07 Javascript
如何在微信小程序中存setStorage
2019/12/13 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
[05:08]第一届“网鱼杯”DOTA2比赛精彩集锦
2014/09/05 DOTA
[02:43]DOTA2亚洲邀请赛场馆攻略——带你走进东方体育中心
2018/03/19 DOTA
Python中多个数组行合并及列合并的方法总结
2018/04/12 Python
Python3.5 Pandas模块之Series用法实例分析
2019/04/23 Python
使用OpenCV circle函数图像上画圆的示例代码
2019/12/27 Python
python实现简单的tcp 文件下载
2020/09/16 Python
python 实现Harris角点检测算法
2020/12/11 Python
Chinti & Parker官网:奢华羊绒女装和创新针织设计
2021/01/01 全球购物
校领导推荐信
2013/11/01 职场文书
运动会通讯稿300字
2014/02/02 职场文书
股权转让协议书
2014/04/12 职场文书
违反交通法规检讨书
2014/09/10 职场文书
小学国庆节活动方案策划书
2014/09/16 职场文书
银行开户授权委托书格式
2014/10/10 职场文书
客户答谢会致辞
2015/07/30 职场文书
一篇文章带你搞懂Python类的相关知识
2021/05/20 Python
“鬼灭之刃”热度不减,其成功背后的原因是什么?
2022/03/22 日漫
Redis如何使用乐观锁(CAS)保证数据一致性
2022/03/25 Redis
SQL SERVER中的流程控制语句
2022/05/25 SQL Server