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 相关文章推荐
jQuery 插件 将this下的div轮番显示
Apr 09 Javascript
jquery ajax执行后台方法
Mar 18 Javascript
js解析与序列化json数据(一)json.stringify()的基本用法
Feb 01 Javascript
javascript阻止浏览器后退事件防止误操作清空表单
Nov 22 Javascript
Javascript 按位与赋值运算符 (&amp;=)使用介绍
Feb 04 Javascript
JavaScript内存管理介绍
Mar 13 Javascript
jquery实现的横向二级导航效果代码
Aug 26 Javascript
vue proxyTable 接口跨域请求调试的示例
Sep 12 Javascript
微信小程序 scroll-view实现锚点滑动的示例
Dec 06 Javascript
解决iView中时间控件选择的时间总是少一天的问题
Mar 15 Javascript
解决vue组件中click事件失效的问题
Nov 09 Javascript
一道JS算法面试题——冒泡、选择排序
Apr 21 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
利用谷歌 Translate API制作自己的翻译脚本
2014/06/04 PHP
WordPress中用于检索模版的相关PHP函数使用解析
2015/12/15 PHP
基于PHP实现堆排序原理及实例详解
2020/06/19 PHP
在IE中调用javascript打开Excel的代码(downmoon原作)
2007/04/02 Javascript
监控 url fragment变化的js代码
2010/04/19 Javascript
JQUERY设置IFRAME的SRC值的代码
2010/11/30 Javascript
使用JS进行目录上传(相当于批量上传)
2010/12/05 Javascript
Bootstrap中CSS的使用方法
2016/02/17 Javascript
js修改onclick动作的四种方法(推荐)
2016/08/18 Javascript
JavaScript仿网易选项卡制作代码
2016/10/06 Javascript
Vue.js开发环境快速搭建教程
2017/03/17 Javascript
vue-router单页面路由
2017/06/17 Javascript
基于JavaScript实现单例模式
2019/10/30 Javascript
解决pycharm安装后代码区不能编辑的问题
2018/10/28 Python
Python爬取商家联系电话以及各种数据的方法
2018/11/10 Python
python面试题Python2.x和Python3.x的区别
2019/05/28 Python
python实战串口助手_解决8串口多个发送的问题
2019/06/12 Python
在Pytorch中使用样本权重(sample_weight)的正确方法
2019/08/17 Python
Python Gluon参数和模块命名操作教程
2019/12/18 Python
Python 时间戳之获取整点凌晨时间戳的操作方法
2020/01/28 Python
keras 自定义loss损失函数,sample在loss上的加权和metric详解
2020/05/23 Python
python3爬虫中引用Queue的实例讲解
2020/11/24 Python
日本最大的购物网站乐天市场国际版:Rakuten Global Market(支持中文)
2020/02/03 全球购物
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
AURALog面试题软件测试方面
2013/10/22 面试题
心理学专业毕业生推荐信范文
2013/11/21 职场文书
运动会通讯稿500字
2014/02/20 职场文书
社区健康教育实施方案
2014/03/18 职场文书
离婚财产处理协议书
2014/09/30 职场文书
2014年妇委会工作总结
2014/12/10 职场文书
十佳少年事迹材料
2014/12/25 职场文书
碧霞祠导游词
2015/02/09 职场文书
2015年护士工作总结范文
2015/03/31 职场文书
2015年国庆放假通知范文
2015/08/18 职场文书
基于Python绘制子图及子图刻度的变换等的问题
2021/05/23 Python
Python进程间的通信之语法学习
2022/04/11 Python