vue中添加广告上下轮播

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<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: white;
background-color: #ff483e;
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: #ff483e;
}

</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">
<div>{{item.title}}</div>
</li>
</ul>
</div>
</div>
</div>

<script type="text/javascript" src="js/vue.min.js"></script>
<script type="text/javascript">
const vm = new Vue({
el: ".vueBox",
data: {
animate: false,
marqueeList: [
{
title:'恭喜桂林子公司加入优客尚品'
},
{
title:'恭喜洛阳子公司加入优客尚品'
},
{
title:'恭喜漯河子公司加入优客尚品'
},
{
title:'恭喜焦作子公司加入优客尚品'
}
]
},
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>

转载于:https://www.cnblogs.com/zlfei/p/8365194.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Vue 表格实现文本上下轮播图,可以使用 CSS3 动画和 Vue 的计时器。 首先,在表格的单元格添加一个包含文本的 div 元素,并添加样式来限制其高度和溢出行为: ``` <td> <div class="text-container"> {{ rowData.text }} </div> </td> <style> .text-container { height: 50px; overflow: hidden; } </style> ``` 接下来,在 div 元素添加一个子元素 span,用于包装文本并应用动画: ``` <td> <div class="text-container"> <span class="text-wrapper">{{ rowData.text }}</span> </div> </td> <style> .text-container { height: 50px; overflow: hidden; } .text-wrapper { display: inline-block; animation: marquee 5s linear infinite; } @keyframes marquee { 0% { transform: translateY(0); } 100% { transform: translateY(-50px); } } </style> ``` 现在,我们可以使用 Vue 的计时器来更新文本的内容,并在动画完成后重新开始: ``` <td> <div class="text-container"> <span class="text-wrapper">{{ currentText }}</span> </div> </td> <script> export default { data() { return { index: 0, texts: [ "Lorem ipsum dolor sit amet", "consectetur adipiscing elit", "sed do eiusmod tempor incididunt", "ut labore et dolore magna aliqua" ] }; }, computed: { currentText() { return this.texts[this.index]; } }, mounted() { setInterval(() => { this.index = (this.index + 1) % this.texts.length; }, 5000); } }; </script> <style> .text-container { height: 50px; overflow: hidden; } .text-wrapper { display: inline-block; animation: marquee 5s linear infinite; } @keyframes marquee { 0% { transform: translateY(0); } 100% { transform: translateY(-50px); } } </style> ``` 这样,我们就可以实现一个文本上下轮播图,可以在表格动态展示多个文本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值