美文网首页
vue-cli实现文字跑马灯

vue-cli实现文字跑马灯

作者: 欧尼小萱 | 来源:发表于2018-05-04 12:28 被阅读0次

刚刚开始学习vue,项目就有一个跑马灯的功能让添加,听说marqueen相当简单,但是听说被弃用了,是这样的,先获取到从数据库获取的文字内容,将它放入labaModel变量中,在created函数中去调用这个方法(相当于进来就走这个方法)

addLabaMessage: function() {
                var self = this;
                const url = 'Notify/LoadUserAllNotify'
                $.kkajax.get(url).then(response => {
                    console.log(response)
                    self.labaModel = response
                }).catch(err => {
                    alert("error");
                })
            },

<!--喇叭-->
            <div class="vueBox" style="background: #fdfbde;">
                <div class="marquee">
                    <div class="marquee_title">
                        <img style="width: 15px; height: 15px; margin-left: 4px;margin-top: 2px;" src="../../assets/home/laba.png" />
                    </div>
                    <div class="marquee_box">
                        <ul class="marquee_list" :class="{marquee_top:animate}">
                            <li v-for="(item, index) in labaModel" :key="index">
                                <span>{{item.content}}</span>
                            </li>
                        </ul>
                    </div>
                </div>
            </div>


然后在created中加个定时器,this.showMarquee也是一个方法

created:function () {
            this.addLabaMessage();
            setInterval(this.showMarquee, 2000);
        }

喇叭数据集合里面添加一个push(this.labaModel[0]),删除一个shift(),然后到这步之后我们再添加一下transition的动画就可以了

showMarquee: function() {
                this.animate = true;
                setTimeout(() => {
                    this.labaModel.push(this.labaModel[0]);
                    this.labaModel.shift();
                    this.animate = false;
                }, 1000)
            }
.marquee {
        width: 100%;
        height: 30px;
        align-items: center;
        color: #3A3A3A;
        background-color: #fdfbde;
        display: flex;
        box-sizing: border-box;
    }

    .marquee_title {
        padding: 0 20px;
        height: 20px;
        font-size: 12px;
        align-items: center;
    }

    .marquee_box {
        display: block;
        position: relative;
        width: 60%;
        height: 30px;
        overflow: hidden;
    }

    .marquee_list {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
    }

    .marquee_top {
        transition: all 0.5s;
        margin-top: -30px
    }

    .marquee_list li {
        height: 30px;
        line-height: 30px;
        font-size: 12px;
        padding-left: 20px;
    }

    .marquee_list li span {
        padding: 0 2px;
        color: #f1543a;
    }
en.gif

相关文章

  • vue-cli实现文字跑马灯

    刚刚开始学习vue,项目就有一个跑马灯的功能让添加,听说marqueen相当简单,但是听说被弃用了,是这样的,先获...

  • iOS 跑马灯

    几行代码实现跑马灯/ 一个Label搞定跑马灯要显示的文字text,宽度为width 。label.text = ...

  • 安卓实现单行文字跑马灯效果

    背景 按照产品设计,文字过长时,需要采用跑马灯显示. 如果是多行文字上下左右切换的跑马灯,可以参考《安卓实现多行文...

  • 自定义XML

    跑马灯 自定义XML 跑马灯 跑马灯的实现方式有两种,这两种方式文字必须超过屏幕的长度第一种:android:fo...

  • 用recyclerview实现跑马灯文字无限轮播

    网上找了一些跑马灯实现都是直接重写的textview不停的改变绘制文字的位置来达到跑马灯效果,但是有的时候需求要求...

  • TextView实现跑马灯

    最简实现文字跑马灯显示: 补: android:shadowDx //设置阴影横向坐标开始位置 android:s...

  • 微信小程序文字跑马灯开发

    一.h5实现跑马灯非常简单, 滚动的文字,配置不同的属性,就...

  • Android实现跑马灯效果

    实现方式1 跑马灯相关属性 实现方式2:自定义跑马灯类 上面方式1能暂时实现跑马灯效果,但在多次点击事件之后容易失...

  • iOS 滚动显示文字

    跑马灯效果滚动显示文字 在网上搜了好多跑马灯效果都能实现,但是看了具体的代码,感觉好复杂的样子,因为很小的一个功能...

  • 2020-02-04

    vue实现跑马灯

网友评论

      本文标题:vue-cli实现文字跑马灯

      本文链接:https://www.haomeiwen.com/subject/aprdrftx.html