vue 實(shí)現(xiàn)走馬燈效果
Part.1 問(wèn)題
在寫(xiě)一個(gè)H5頁(yè)面時(shí)遇到一個(gè)需求,頭部公告需要滾動(dòng)變換,需要實(shí)現(xiàn)一個(gè)走馬燈效果
Part.2 實(shí)現(xiàn)
我的做法:利用 定時(shí)器 + CSS3 變換公告數(shù)組的順序 從而實(shí)現(xiàn)走馬燈效果
Part.3 代碼
HTML
<template>
<div class="home">
<div class="home-box">
<div style="background: #fdfbde">
<div class="marquee">
<div class="marquee_box">
<ul class="marquee_list" :class="{marquee_top:animate}">
<li v-for="(item, index) in announcementArr" :key="index">
<span>{{item}}</span>
</li>
</ul>
</div>
</div>
</div>
</div>
</div>
</template>
CSS
<style type="text/css">
.home {
height: 100%;
display: flex;
justify-content: center;
align-items: center;
}
.home-box {
width: 200px;
height: 200px;
}
.marquee {
width: 100%;
height: 30px;
align-items: center;
color: #3A3A3A;
background-color: #fdfbde;
display: flex;
box-sizing: border-box;
}
.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;
}
</style>
JS
<script>
export default {
name: 'Home',
data() {
return {
announcementArr: [],
animate: false
}
},
mounted() {
this.addAnnouncement();
setInterval(this.showMarquee, 2000);
},
methods: {
addAnnouncement: function() {
this.announcementArr = ['測(cè)試滾動(dòng)001','測(cè)試滾動(dòng)002','測(cè)試滾動(dòng)003','測(cè)試滾動(dòng)004']
},
showMarquee: function() {
this.animate = true;
setTimeout(() => {
this.announcementArr.push(this.announcementArr[0]);
this.announcementArr.shift();
this.animate = false
}, 1000)
}
}
}
</script>
Part.4 注意點(diǎn)
在 js 中我使用的是 setInterval 中 利用 setTimeout 來(lái)調(diào)用方法
方法詳解:
setInterval —— 會(huì)不停的調(diào)用函數(shù)
setTimeout —— 只會(huì)執(zhí)行函數(shù)一次
這么寫(xiě)的原因:
如果單純的使用 setInterval 會(huì)導(dǎo)致頁(yè)面卡死,原因與JS引擎線程有關(guān)(有興趣的童鞋可以研究一下),setInterval 不會(huì)清除定時(shí)器隊(duì)列,每次重復(fù)執(zhí)行會(huì)導(dǎo)致定時(shí)器疊加,最終卡死網(wǎng)頁(yè)。而 setTimeout 是自帶清除定時(shí)器的
Part.5 效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
van-picker組件default-index屬性設(shè)置不生效踩坑及解決
這篇文章主要介紹了van-picker組件default-index屬性設(shè)置不生效踩坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
nginx+vite項(xiàng)目打包以及部署的詳細(xì)過(guò)程
我們使用nginx部署Vue項(xiàng)目,實(shí)質(zhì)上就是將Vue項(xiàng)目打包后的內(nèi)容同步到nginx指向的文件夾,下面這篇文章主要給大家介紹了關(guān)于nginx+vite項(xiàng)目打包以及部署的相關(guān)資料,需要的朋友可以參考下2023-01-01
vue2+element-ui使用vue-i18n進(jìn)行國(guó)際化的多語(yǔ)言/國(guó)際化詳細(xì)教程
這篇文章主要給大家介紹了關(guān)于vue2+element-ui使用vue-i18n進(jìn)行國(guó)際化的多語(yǔ)言/國(guó)際化的相關(guān)資料,I18n是Vue.js的國(guó)際化插件,項(xiàng)目里面的中英文等多語(yǔ)言切換會(huì)使用到這個(gè)東西,需要的朋友可以參考下2023-12-12
淺談Vue使用Elementui修改默認(rèn)的最快方法
這篇文章主要介紹了淺談Vue使用Elementui修改默認(rèn)的最快方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
vue3使用富文本編輯器Editor.js的簡(jiǎn)單方法
Editor.js是一個(gè)用于構(gòu)建具有完全可定制化塊結(jié)構(gòu)的現(xiàn)代編輯器的開(kāi)源庫(kù),它提供了一個(gè)簡(jiǎn)潔、可擴(kuò)展和易于使用的接口,使開(kāi)發(fā)人員能夠創(chuàng)建擁有豐富內(nèi)容和互動(dòng)性的編輯器,這篇文章主要給大家介紹了關(guān)于vue3使用富文本編輯器Editor.js的簡(jiǎn)單方法,需要的朋友可以參考下2024-04-04
基于Vue技術(shù)實(shí)現(xiàn)遞歸組件的方法
這篇文章主要為大家詳細(xì)介紹了基于Vue技術(shù)實(shí)現(xiàn)遞歸組件的方法 ,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
element日期選擇器el-date-picker樣式圖文詳解
最近寫(xiě)的項(xiàng)目里面有一個(gè)功能是日期選擇功能,第一反應(yīng)是使用element里面的el-date-picker組件,下面這篇文章主要給大家介紹了關(guān)于element日期選擇器el-date-picker樣式的相關(guān)資料,需要的朋友可以參考下2022-09-09

