javascript实现文字跑马灯效果


Posted in Javascript onJune 18, 2020

本文实例为大家分享了js实现文字跑马灯效果的具体代码,供大家参考,具体内容如下

思路:

1.判断文字的长度和容器的长度,如果文字长度大于容器长度,则开始滚动,否则不滚动。

2.获取滚动条到元素左边的距离,递归滚动,直到滚动后的距离等于文字的长度退出递归。

判断文字和容器的长度可以通过offsetWidth来判断。如果文字长度大于容器长度,则开始滚动。

window.onload = function(){
       //比较文字与盒子长度的大小
       if(boxWidth>textWidth){
        return false;
       }
       content.innerHTML += content.innerHTML;
       document.querySelector('.text').classList.add('padding');
       //刷新textwidth
       textWidth = document.querySelector('.text').offsetWidth;
       scroll_left();
     }

判断滚动的结束根据滚动条到元素左边的距离和文字的长度判断,如果滚动条到元素左边的距离等于文字的长度,则结束滚动。

function scroll_left(){
    if(textWidth>boxWidth){
     //文字长度大于盒子长度,开始滚动
       box.scrollLeft++;
      setTimeout('scroll_left()',1);
   }
}

完整代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    *{
      margin: auto;
      padding: 0;
    }
    .box{
      margin-top: 150px;
      margin-left: 150px;
      color: red;
      white-space: nowrap;
      width: 200px;
      background: rosybrown;
      overflow: hidden;
    }
    .content p{
      display: inline-block;
    }
    .content p.padding{
      padding-right: 200px;
    }
  </style>
  


</head>
<body>
  <div class="box">
    <div class="content">
      <p class="text">实现文字的跑马灯效果,超出容器的长度则开始向左滚动</p>
    </div>
  </div>


  <script>
    
     let box = document.querySelector('.box');
     let content = document.querySelector('.content');
     let text = document.querySelector('.text');

    //文本宽度
    let textWidth = text.offsetWidth;
    //盒子宽度
    let boxWidth = text.offsetWidth;


     window.onload = function(){
       //比较文字与盒子长度的大小
       if(boxWidth>textWidth){
        return false;
       }
       content.innerHTML += content.innerHTML;
       document.querySelector('.text').classList.add('padding');
       //刷新textwidth
       textWidth = document.querySelector('.text').offsetWidth;
       scroll_left();
     }

     function scroll_left(){
       if(textWidth>boxWidth){
         //文字长度大于盒子长度,开始滚动
         box.scrollLeft++;
         setTimeout('scroll_left()',1);
       }
     }
  </script>

</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
xml 封装与解析(javascript和C#中)
Jul 26 Javascript
基于Jquery的仿照flash放大图片效果代码
Mar 16 Javascript
类似php的js数组的in_array函数自定义方法
Dec 27 Javascript
详解JavaScript正则表达式之RegExp对象
Dec 13 Javascript
JavaScript实现下拉菜单的显示和隐藏
Jan 05 Javascript
对jquery的ajax进行二次封装以及ajax缓存代理组件:AjaxCache详解
Apr 11 Javascript
Vue.js中兄弟组件之间互相传值实例
Jun 01 Javascript
vue实现移动端图片裁剪上传功能
Aug 18 Javascript
微信小程序实现下载进度条的方法
Dec 08 Javascript
深入理解vue中的slot与slot-scope
Apr 22 Javascript
解决layui动态添加的元素click等事件触发不了的问题
Sep 20 Javascript
vue 开发之路由配置方法详解
Dec 02 Javascript
node.js +mongdb实现登录功能
Jun 18 #Javascript
VSCode launch.json配置详细教程
Jun 18 #Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 #Javascript
通过实例了解JS执行上下文运行原理
Jun 17 #Javascript
从0搭建vue-cli4脚手架
Jun 17 #Javascript
微信小程序点击生成朋友圈分享图(遇到的坑)
Jun 17 #Javascript
基于JS+HTML实现弹窗提示是否确认提交功能
Jun 17 #Javascript
You might like
php环境配置 php5 mysql5 apache2 phpmyadmin安装与配置
2006/11/17 PHP
PHP初学入门
2006/11/19 PHP
php htmlspecialchars加强版
2010/02/16 PHP
PHP+MariaDB数据库操作基本技巧备忘总结
2018/05/21 PHP
javascript 冒号 使用说明
2009/06/06 Javascript
javascript数组去掉重复
2011/05/12 Javascript
改善用户体验的五款jQuery插件分享
2011/05/22 Javascript
如何在MVC应用程序中使用Jquery
2014/11/17 Javascript
jQuery中outerHeight()方法用法实例
2015/01/19 Javascript
Jquery插件实现点击获取验证码后60秒内禁止重新获取
2015/03/13 Javascript
一个字符串中出现次数最多的字符 统计这个次数【实现代码】
2016/04/29 Javascript
JS实现复制功能
2017/03/01 Javascript
vue下history模式刷新后404错误解决方法
2018/08/18 Javascript
浅谈对于react-thunk中间件的简单理解
2019/05/01 Javascript
使vue实现jQuery调用的两种方法
2019/05/12 jQuery
layui导出所有数据的例子
2019/09/10 Javascript
layui实现checkbox的目录树tree的例子
2019/09/12 Javascript
基于vue的video播放器的实现示例
2021/02/19 Vue.js
Python实现多线程下载文件的代码实例
2014/06/01 Python
在Django的URLconf中使用命名组的方法
2015/07/18 Python
python字符类型的一些方法小结
2016/05/16 Python
如何更优雅地写python代码
2019/07/02 Python
Python sep参数使用方法详解
2020/02/12 Python
python小程序基于Jupyter实现天气查询的方法
2020/03/27 Python
Python GUI编程学习笔记之tkinter事件绑定操作详解
2020/03/30 Python
Numpy中np.random.rand()和np.random.randn() 用法和区别详解
2020/10/23 Python
Python批量删除mysql中千万级大量数据的脚本分享
2020/12/03 Python
课堂教学改革实施方案
2014/03/17 职场文书
企业宣传标语
2014/06/09 职场文书
致地震灾区的慰问信
2015/03/23 职场文书
五一晚会主持词
2015/07/01 职场文书
2016春季校长开学典礼致辞
2015/11/26 职场文书
最新农村养殖致富:资金投入较低的创业项目有哪些?
2019/09/26 职场文书
深度学习详解之初试机器学习
2021/04/14 Python
正确使用MySQL update语句
2021/05/26 MySQL
Nginx跨域问题解析与解决
2022/08/05 Servers