JS实现横向跑马灯效果代码


Posted in Javascript onApril 20, 2020

首先我们需要一个html代码的框架如下:

<div style="position: absolute; top: 0px; left: 168px; width: 100%; margin-left: auto; margin-right: auto; height: 47px; border: 0px solid red; overflow: hidden;">
    <ul id="syNoticeUlNew" style="margin: 0px;left:0; top:0;margin-bottom:0px;width:100%;height:47px;position:absolute;">

    </ul>
  </div>

我们的目的是实现ul中的内容进行横向的一点一点滚动。ul中的内容应该是动态的。于是应该发送ajax来进行内容的获取拼接。

$.ajax({
      type:"post",
      dataType:"json",
      url:"${contextPath}/indexPage/getSyNoticeInfo",
      success:function(result){
        var totalStr = "";
        if(result.length>0){
          for(var i=0 ; i<result.length;i++){
            str = "<li style=\"list-style: none;display:inline-block;float:left;height:47px;padding-right:50px;line-height:47px;\">"+
             "<a style=\"color:white;\" class=\"sstzNoticeStyle\">"+result[i].peopleName+"</a>"+
             "</li>";
            totalStr +=str;
          }
        }
        $("#syNoticeUlNew").empty();
        $('#syNoticeUlNew').html(totalStr);
        syRunHorseLight();
      }
    });

拼接li时候有个class为sstzNoticeStyle。其样式如下:

.sstzNoticeStyle{
  color:white; font-size:16px;text-decoration:none;
}
.sstzNoticeStyle:hover{
  color:white; font-size:16px;text-decoration:none;
}

ajax调用syRunHorseLight函数,函数如下:

function syRunHorseLight() {
    if (syTimer != null) {
      clearInterval(syTimer);
    }
    var oUl = document.getElementById("syNoticeUlNew");
    if(oUl != null){
      oUl.innerHTML += oUl.innerHTML;
      oUl.innerHTML += oUl.innerHTML;
      oUl.innerHTML += oUl.innerHTML;
      var lis = oUl.getElementsByTagName('li');
      var lisTotalWidth = 0;
      var resetWidth = 0;
      for (var i = 0; i < lis.length; i++) {
        lisTotalWidth += lis[i].offsetWidth;
      }
      for (var i = 1; i <= lis.length / 4; i++) {
        resetWidth += lis[i].offsetWidth;
      }
      oUl.style.width = lisTotalWidth + 'px';
      var left = 0;
      syTimer = setInterval(function() {
        left -= 1;
        if (left <= -resetWidth) {
          left = 0;
        }
        oUl.style.left = left + 'px';
      }, 20)
      $("#syNoticeUlNew").hover(function() {
        clearInterval(syTimer);
      }, function() {
        clearInterval(syTimer);
        syTimer = setInterval(function() {
          left -= 1;
          if (left <= -resetWidth) {
            left = 0;
          }
          oUl.style.left = left + 'px';
        }, 20);
      })
    }
  }

跑马灯效果就此实现。

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

Javascript 相关文章推荐
10个新的最有前途的JavaScript框架
Mar 12 Javascript
JavaScript 创建对象和构造类实现代码
Jul 30 Javascript
JQuery Ajax 跨域访问的解决方案
Mar 12 Javascript
javascript作用域容易记错的两个地方分析
Jun 22 Javascript
js+html+css实现鼠标移动div实例
Jan 30 Javascript
通过伪协议解决父页面与iframe页面通信的问题
Apr 05 Javascript
CascadeView级联组件实现思路详解(分离思想和单链表)
Apr 12 Javascript
jQuery EasyUI右键菜单实现关闭标签/选项卡
Oct 10 Javascript
js文件中直接alert()中文出来的是乱码的解决方法
Nov 01 Javascript
bootstrap提示标签、提示框实现代码
Dec 28 Javascript
vue中子组件的methods中获取到props中的值方法
Aug 27 Javascript
Vue的click事件防抖和节流处理详解
Nov 13 Javascript
vue2.x数组劫持原理的实现
Apr 19 #Javascript
vue2.x 对象劫持的原理实现
Apr 19 #Javascript
基于js判断浏览器是否支持webGL
Apr 18 #Javascript
JavaScript对象字面量和构造函数原理与用法详解
Apr 18 #Javascript
javascript 内存模型实例详解
Apr 18 #Javascript
javascript-hashchange事件和历史状态管理实例分析
Apr 18 #Javascript
javascript使用Blob对象实现的下载文件操作示例
Apr 18 #Javascript
You might like
生成php程序的php代码
2008/04/07 PHP
php 记录进行累加并显示总时长为秒的结果
2011/11/04 PHP
利用php实现禁用IE和火狐的缓存问题
2012/12/03 PHP
php中mail函数发送邮件失败的解决方法
2014/12/24 PHP
PHP中调用SVN命令更新网站方法
2015/01/07 PHP
PHP获取昨天、今天及明天日期的方法
2016/02/03 PHP
PHP有序表查找之插值查找算法示例
2018/02/10 PHP
Javascript操纵Cookie实现购物车程序
2006/11/23 Javascript
JavaScript更改class和id的方法
2008/10/10 Javascript
jquery 插件学习(六)
2012/08/06 Javascript
通过javascript获取iframe里的值示例代码
2013/06/24 Javascript
JS 退出系统并跳转到登录界面的实现代码
2013/06/29 Javascript
Javascript学习笔记之 函数篇(一) : 函数声明和函数表达式
2014/06/24 Javascript
js实现的光标位置工具函数示例
2016/10/03 Javascript
JavaScript基础——使用Canvas绘图
2016/11/02 Javascript
nodejs异步编程基础之回调函数用法分析
2018/12/26 NodeJs
微信小程序获取地理位置及经纬度授权代码实例
2019/09/18 Javascript
node.JS的crypto加密模块使用方法详解(MD5,AES,Hmac,Diffie-Hellman加密)
2020/02/06 Javascript
JS highcharts动态柱状图原理及实现
2020/10/16 Javascript
利用JavaScript模拟京东按键输入功能
2020/12/01 Javascript
Python使用functools模块中的partial函数生成偏函数
2016/07/02 Python
Django Admin 实现外键过滤的方法
2017/09/29 Python
Python程序退出方式小结
2017/12/09 Python
Python二叉树定义与遍历方法实例分析
2018/05/25 Python
python开发准备工作之配置虚拟环境(非常重要)
2019/02/11 Python
Python使用Tkinter实现转盘抽奖器的步骤详解
2020/01/06 Python
Pycharm学生免费专业版安装教程的方法步骤
2020/09/24 Python
mui几种页面跳转方式对比总结概括
2017/08/18 HTML / CSS
西雅图的买手店:Totokaelo
2019/10/19 全球购物
美国最大最全的亚洲购物网站:美国亚米网(Yamibuy)
2020/05/05 全球购物
担保书怎么写
2014/04/01 职场文书
祖国在我心中演讲稿600字
2014/09/23 职场文书
五星级酒店前台接待岗位职责
2015/04/02 职场文书
工厂员工辞职信范文
2015/05/12 职场文书
2016年禁毒宣传活动总结
2016/04/05 职场文书
聘任书的格式及模板
2019/10/28 职场文书