实现移动端信息无缝滚动

站长手记 作者: 2024-08-28 02:05:01
这篇文章主要教大家如何简单实现js无缝滚动效果。这种实例在网页中其实还挺常见的。注意:内容的高度必须大于容器的高度,否则无法滚动
<div style="position:relative; height:5rem">
      <div id="demo" style="position:absolute;width:100%;height: 4rem; overflow:hidden; text-align:center;margin: .5rem 0;">
         <div id="demo1">
               <p><span>广东省广州市 网友:186****0751</span>通过提交需求得到了律师帮助</p>
               <p><span>江苏省南京市 网友:138****7913</span>通过提交需求得到了律师帮助</p>
               <p><span>广西省南宁市 网友:136****8755</span>通过提交需求得到了律师帮助</p>
               <p><span>浙江省杭州市 网友:188****3421</span>通过提交需求得到了律师帮助</p>
               <p><span>广东省惠州市 网友:134****2244</span>通过提交需求得到了律师帮助</p>
               <p><span>广东省东莞市 网友:132****9649</span>通过提交需求得到了律师帮助</p>
               <p><span>湖南省长沙市 网友:138****1354</span>通过提交需求得到了律师帮助</p>
               <p><span>湖北省武汉市 网友:189****8828</span>通过提交需求得到了律师帮助</p>
         </div>
         <div id="demo2"></div>
      </div>
</div>
css代码:
#demo div{
   color: #3a3a3a;
   font-size: .34rem;
   line-height: .8rem;
}

#demo div span{
   color: #f65c53;
}
<script>
      var speed = 40
      var demo = document.getElementById("demo");
      var demo2 = document.getElementById("demo2");
      var demo1 = document.getElementById("demo1");
      demo2.innerHTML = demo1.innerHTML;
      function Marquee() {
         if (demo2.offsetTop - demo.scrollTop <= 0) {
            demo.scrollTop -= demo1.offsetHeight;
         } else {
            demo.scrollTop++;
         }
      }
      var MyMar = setInterval(Marquee, speed);
      demo.onmouseover = function () { clearInterval(MyMar) }
      demo.onmouseout = function () { MyMar = setInterval(Marquee, speed) }
</script>
注意:内容的高度必须大于容器的高度,否则无法滚动
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_69871.html
移动端信息