如何用vue实现上下轮播公告栏,文字溢出时也能轮播

在网上搜到了相关代码,可是有个需求是如果文字溢出时也需要换行轮播,请问如何实现,现在的这个实现不了。。。只会一闪而过

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">

<title>最新战报</title>

<style>

div, ul, li, span, img {
  margin: 0;
  padding: 0;
  display: flex;
  box-sizing: border-box;
}
.marquee {
  width: 100%;
  height: 50px;
  align-items: center;
  color: #3A3A3A;
  background-color: #b3effe;
  display: flex;
  box-sizing: border-box;
}

.marquee_title {
  padding: 0 20px;
  height: 30px;
  font-size: 14px;
  border-right: 1px solid #d8d8d8;
  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: 14px;
  padding-left: 20px;
}

.marquee_list li span {
  padding: 0 2px;
}

.red {
  color: #FF0101;
}

</style>

</head>
<body>

<div class="vueBox">
<div class="marquee">

<div class="marquee_title">
  <span>最新战报</span>
</div>
<div class="marquee_box">
  <ul class="marquee_list" :class="{marquee_top:animate}">
    <li v-for="(item, index) in marqueeList">
      <span>{{item.name}}</span>
      <span>在</span>
      <span class="red"> {{item.city}}</span>
      <span>杀敌</span>
      <span class="red"> {{item.amount}}</span>
      <span>万</span>
    </li>
  </ul>
</div>

</div>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script type="text/javascript">
const vm = new Vue({

el: ".vueBox",
data: {
  animate: false,
  marqueeList: [
    {
      name: '1军',
      city: '北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京 北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京北京',
      amount: '10'
    },
    {
      name: '2军',
      city: '上海',
      amount: '20'
    },
    {
      name: '3军',
      city: '广州',
      amount: '30'
    },
    {
      name: '4军',
      city: '重庆',
      amount: '40'
    }
  ]
},
created: function () {
  setInterval(this.showMarquee, 2000)
},
methods: {
  showMarquee: function () {
    this.animate = true;
    setTimeout(()=>{
      this.marqueeList.push(this.marqueeList[0]);
      this.marqueeList.shift();
      this.animate = false;
    },500)},
}

});
</script>

</body>
</html>

阅读 3.3k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题