JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解


Posted in Javascript onSeptember 19, 2017

本文实例讲述了JavaScript实现的原生态兼容IE6可调可控滚动文字功能。分享给大家供大家参考,具体如下:

虽然HTML里面本身就有marquee标签,用来设置滚动文字(marquee标签在附录【HTML比较冷门标签与属性】里会有具体介绍)这个标签到了IE8就开始不支持,在IE6中可以设置的东西也很少,所以这东西还是用javascript来写为好。这个小组件也是比较常见的,但是网上的代码质量还是为了很多无关紧要的小特效而增加了许多无谓的代码。其实这东西,你只要弄得能自己向右向左滚,到了屏幕边缘自动返回就行了,为什么要为了一些淡入淡出的华而不实的东西,而写一大摞代码了。下面介绍一个自己写的利用padding-left实现滚动文字,因为padding-left这个东西在大多数浏览器还是没有问题的。

一、基本目标

如下图,一开始文字能在15px-400px这个区域以每0.05s,5px像素的无缝滚动,当然,改改下面的脚本,你让我从地球滚动到外太空都没问题,只要你告诉我地球的px和外太空的px就行了,然后设置两个按钮,你点击“停止”它就停止,停止之后点击“开始”就让它开始,它在“开始”的状态你点N下“开始”是不会出BUG的,继续保持这个状态,它在“停止”状态,你点N下“停止”也是没有问题的。

JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解

二、HTML布局

代码如下:

<!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>marquee</title>
</head>
<body>
<div>sssssss</div>
<div id="marquee" style="padding-left:0px;">marquee</div>
<div>sssssss</div>
<button onclick="return marquee_move_stop()">停止</button>
<button onclick="return marquee_move_start()">开始</button>
</body>
</html>

思想如下图,一图胜千言,不说了。请自行对比代码与图。

JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解

三、脚本部分

这里是整个控件的核心。

<script>
//设置其滚动速度是5px/0.05s,这样能够实现无缝滚动,不会一卡一卡的。
var speed=5;
var marqueeTimer=setInterval("marquee_move()",50);
//这个变量主要是用来下面控制滚动开始与停止的两个函数
var isMarqueeMove=true;
//滚动的核心函数
function marquee_move(){
  //这么长的代码主要是为了把带px的padding-left转化为一个可以操作的数
  //如padding-left:0px;经过这一行代码之后var marquee_x=0;
  var marquee_x=parseInt(document.getElementById("marquee").style.paddingLeft.substring(0,document.getElementById("marquee").style.paddingLeft.indexOf("px")));
  //如果滚过400px这个位置,那就向反方向走,反之亦然
  if(marquee_x>400){
    speed=-5;
  }
  //这里不要设置成0,可能会产生越界bug
  if(marquee_x<15){
    speed=5;
  }
  //文字向右滚5px
  document.getElementById("marquee").style.paddingLeft=marquee_x+speed+"px";
}
//下面控制滚动开始与停止的两个函数
//之所以要立flag,是因为marqueeTimer=setInterval("marquee_move()",50);多次被执行,滚动会变得很快和无法控制
//后方的计时器不会替换到前方的计时器
function marquee_move_stop(){
  if(isMarqueeMove){
    clearTimeout(marqueeTimer);
    isMarqueeMove=false;
  }
}
function marquee_move_start(){
  if(!isMarqueeMove){
    marqueeTimer=setInterval("marquee_move()",50);
    isMarqueeMove=true;
  }
}
</script>

四、总结

1、CSS中,凡是带-的属性,在javascript要换成大写,如CSS的padding-left在javascript是paddingLeft,否则会被当成减号处理

2、利用padding-left来完成这个组件,就不用使用left要设置绝对定位,然后又要考虑这个组件怎么摆放了。

3、这个东西在浏览器的百分比宽度内滚动,最好不要这样做,毕竟javascript中取出浏览器的宽度可能会遇到各种各样的兼容性问题。还是设置一个定值,这样的代码简短。

附:HTML比较冷门标签与属性

1.<hr>标签能够添加一条水平分隔线。单标记标签,拥有属性width,size,color,align(后接值)noshade(直接添加,如文本框的disabled,表示这条水平线是无阴影的)

2.<marquee>标签已经被微软废除了。

微软这个家伙在最新的IE8下已经放弃对MARQUEE的支持了(我这里很无语,MARQUEE是微软自己创造出来的,现在火狐都支持了,它自己不干了)

用marquee有诸多问题的。DW给你提示是警告你慎重。

如下面的代码在IE8的滚动是存在问题的,当图片滚完之后会自动刷新,相当难看,无法现实无缝滚动。

<!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>
</head>
<body>
<marquee width=250px behavior="scroll">
<a href="http://www.163.com" rel="external nofollow" ><img src="img0.jpg" width=100 hspace=50/></a>
<a href="http://www.baidu.com" rel="external nofollow" ><img src="img28.jpg" width=100px /></a>
</marquee>
</body>
</html>

3.<strong>标签是强调标签,基于内容。<b>是物理样式。<sup><sub>双标记标签能分别使字体上标与下标

4.©是代表版权字符©,®则是注册商标, 是空格

5.对于图片,其hspace属性能够设置图片与图片之间的间距。

6.<body>标签也是有属性的vlink link 能够分别设置访问了与未访问超链接的颜色,leftmargin与topmargin能够分别规定文档的左边距与上边距

7.<meta name="keywords" content="搜索关键词"><meta name="description content="网页描述">能分别设置被搜索引擎抓取的关键词与网页描述

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

Javascript 相关文章推荐
JS类中定义原型方法的两种实现的区别
Mar 08 Javascript
jQuery select表单提交省市区城市三级联动核心代码
Jun 09 Javascript
[原创]推荐10款最热门jQuery UI框架
Aug 19 Javascript
jQuery实现ichat在线客服插件
Dec 29 Javascript
介绍JavaScript中Math.abs()方法的使用
Jun 14 Javascript
JS动态加载脚本并执行回调操作
Aug 24 Javascript
js实现图片切换(动画版)
Dec 25 Javascript
Bootstrap源码解读媒体对象、列表组和面板(10)
Dec 26 Javascript
jQuery插件HighCharts实现的2D面积图效果示例【附demo源码下载】
Mar 15 Javascript
JavaScript实现与使用发布/订阅模式详解
Jan 19 Javascript
vue cli3.0 引入eslint 结合vscode使用
May 27 Javascript
编写一个javascript元循环求值器的方法
Apr 14 Javascript
vue实现页面加载动画效果
Sep 19 #Javascript
深入理解Node.js中通用基础设计模式
Sep 19 #Javascript
微信小程序媒体组件详解(视频,音乐,图片)
Sep 19 #Javascript
Javascript中将变量转换为字符串的三种方法
Sep 19 #Javascript
详解JS中的this、apply、call、bind(经典面试题)
Sep 19 #Javascript
JavaScript 中的 this 简单规则
Sep 19 #Javascript
在 Node.js 中使用原生 ES 模块方法解析
Sep 19 #Javascript
You might like
用文本文件制作留言板提示(下)
2006/10/09 PHP
Apache中php.ini的设置方法
2013/02/28 PHP
PHP数组Key强制类型转换实现原理解析
2020/09/01 PHP
编辑浪子版表单验证类
2007/05/12 Javascript
JS中==与===操作符的比较
2009/03/21 Javascript
理解JAVASCRIPT中hasOwnProperty()的作用
2013/06/05 Javascript
jQuery Html控件基本操作(日常收集整理)
2016/03/11 Javascript
jQuery实现HTML表格单元格的合并功能
2016/04/06 Javascript
KnockoutJS 3.X API 第四章之click绑定
2016/10/10 Javascript
如何解决hover在ie6中的兼容性问题
2016/12/15 Javascript
jQuery 循环遍历改变a标签的href(实例讲解)
2017/07/12 jQuery
vue项目tween方法实现返回顶部的示例代码
2018/03/02 Javascript
详解vue-cli中模拟数据的两种方法
2018/07/03 Javascript
layui select获取自定义属性方法
2018/08/15 Javascript
element-ui多文件上传的实现示例
2019/04/10 Javascript
jQuery实现的记住帐号密码功能完整示例
2019/08/03 jQuery
JS严格模式原理与用法实例分析
2020/04/27 Javascript
微信小程序轮播图swiper代码详解
2020/12/01 Javascript
跟老齐学Python之有容乃大的list(2)
2014/09/15 Python
Python函数嵌套实例
2014/09/23 Python
Python编程修改MP3文件名称的方法
2017/04/19 Python
Python安装Numpy和matplotlib的方法(推荐)
2017/11/02 Python
django文档学习之applications使用详解
2018/01/29 Python
python学生管理系统
2019/01/30 Python
Python docx库用法示例分析
2019/02/16 Python
华为2019校招笔试题之处理字符串(python版)
2019/06/25 Python
pytorch 图像预处理之减去均值,除以方差的实例
2020/01/02 Python
Django实现任意文件上传(最简单的方法)
2020/06/03 Python
使用css3做0.5px的细线的示例代码
2018/01/18 HTML / CSS
html5调用app分享功能示例(WebViewJavascriptBridge)
2018/03/21 HTML / CSS
美国精油公司:Plant Therapy
2019/05/17 全球购物
《草虫的村落》教学反思
2014/02/16 职场文书
办公设备采购方案
2014/03/16 职场文书
计算机专业自荐信
2015/03/05 职场文书
原来实习报告是这样写的呀!
2019/07/03 职场文书
Oracle 多表查询基本语法实例
2022/04/18 Oracle