欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jQuery实现的上下滚动公告栏详细讲解

程序员文章站 2022-04-24 18:29:08
之前做项目的时候,一直都想着做一个上下滚动的公告栏,作为展示网站的最新公告信息,因为刚开始自己的思路并不是太清晰,在网上找了很多的源码,但是却发现都不能让自己满意,有的还会出现一些小问题,比如,有时候公告上下滚动的时候,两条公告会重叠在一起。最后我还是决定自己写一个上下滚动的公告栏。 jQuery实 ......

之前做项目的时候,一直都想着做一个上下滚动的公告栏,作为展示网站的最新公告信息,因为刚开始自己的思路并不是太清晰,在网上找了很多的源码,但是却发现都不能让自己满意,有的还会出现一些小问题,比如,有时候公告上下滚动的时候,两条公告会重叠在一起。最后我还是决定自己写一个上下滚动的公告栏。

jquery实现上下滚动公告栏原理

虽然在网上找的有些代码有时候会出现一些问题,但是思路咱还是可以借鉴一下的。
我们先来看一下,我做的上下滚动公告栏效果图,如果你感觉是你要的那款,那么你再接着往下看是怎么实现的。

jQuery实现的上下滚动公告栏详细讲解

图中箭头所指内容就是公告内容,它会不停的上下滚动,当然滚动时间可以自己设置的。
下面我们来看下是怎么实现的。
其实实现滚动效果主要用到jquery中的animate() 方法,而animate() 方法就是创建动画效果,简单的说就是,当我们用js将“一棵树”的height属性从100px变为200px的时候,我们会看到“这个树”瞬间从100高度长到了200高度,但是我们用animate() 方法,我们会看到“这颗树”从100高度慢慢的长到200高度,我们可以看到这个过程,这就是animate() 方法的作用,当然“树”的生长速度是可以控制的。
了解了jquery的animate()方法,我们还需要了解一下setinterval( )这个方法,可能很多同学知道这个方法,因为它就是一个简单的定时函数,我们看一下它的用法

setinterval(function(){ alert("hello"); }, 3000);

这句代码就是每过3秒执行一次该方法,弹出一个“hello”。
好了,理解了前面的两个方法,那么下面的代码你一定可以看懂得。

<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <title>滚动公告栏</title>
    <script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
    <style type="text/css">
        body{padding: 0;margin:0;background-color:#f9f9f9}
        .ul1{list-style: none;margin: 0}
        li{padding: 5px;}
    </style>
</head>
<body>
<div style="height: 60px;background-color: #191e29;">
    <p style="margin: 0;color: #fff;line-height: 60px;text-align: center;">这是用jquery实现的上下滚动公告栏</p>
</div>
<div style="background-image: url(timg.jpg); margin:15px 90px 0 90px;padding-left: 310px; height: 600px;">
    <div style="position: relative;height: 26px;overflow: hidden;">
        <ul class="ul1">
            <li>k先生:我求求你嫁给我</li>
            <li>k先生:等你老了,我依然背着你</li>
            <li>k先生:我给你当拐杖</li>
            <li>k先生:等你没牙了,我就嚼碎了再喂给你吃</li>
        </ul>
        <img style="position: absolute;top: 9px;left: 20px" width="15px" height="15px" src="laba.png">
    </div>
</div>
<script type="text/javascript">
    $(function(){
        var num=$(".ul1").find("li").length;
        console.log("直接运行"+num);
        if (num>1) {
            setinterval(function(){ 
            $('.ul1').animate({
                margintop:"-26px"
            },500,function(){
                $(this).css({margintop : "0"}).find("li:first").appendto(this);
            });
        }, 3000);
        }
                
    });
</script>
</body>
</html>

如果你有更好得建议或者问题,欢迎下方留言哦。
本篇文章来自k先生的博客(有源码哦)。