欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue通過定時(shí)器實(shí)現(xiàn)垂直滾動(dòng)公告

 更新時(shí)間:2022年04月08日 10:31:46   作者:鐵錘妹妹@  
這篇文章主要為大家詳細(xì)介紹了vue通過定時(shí)器實(shí)現(xiàn)垂直滾動(dòng)公告,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

最近項(xiàng)目有個(gè)需求是做一個(gè)垂直滾動(dòng)的公告,其中也涉及到了設(shè)置定時(shí)器和清除定時(shí)器方面的知識(shí)點(diǎn),在這里記錄下過程,不對(duì)的地方歡迎大家指正,一起共同進(jìn)步!

思路

1. 寫好樣式,把滾動(dòng)的內(nèi)容循環(huán)出來,固定顯示區(qū)域的高度,超出隱藏
2. 設(shè)置定時(shí)器,將第一條數(shù)據(jù)塞到最后一個(gè),刪除第一條數(shù)據(jù),暫停播放
3. 在mounted中創(chuàng)建并執(zhí)行定時(shí)器
4. destroyed中清除定時(shí)器

HTML部分

<div class="roll">
? ? ? <div class="roll-line" />
? ? ? <i class="el-icon-bell"></i>
? ? ? <ul class="list">
? ? ? ? <li
? ? ? ? ? v-for="(item, index) in ulList"
? ? ? ? ? :key="item.id"
? ? ? ? ? :class="!index && play ? 'toUp' : ''"
? ? ? ? >
? ? ? ? ? {{ item.msg }}
? ? ? ? </li>
? ? ? </ul>
</div>

JS部分

export default {
? data() {
? ? return {
? ? ? ulList: [
? ? ? ? { msg: "這是第一條信息這是第一條信息這是第一條信息這是第一條信息" },
? ? ? ? { msg: "這是第二條信息這是第二條信息這是第二條信息這是第二條信息" },
? ? ? ? { msg: "這是第三條信息這是第三條信息這是第三條信息這是第三條信息" },
? ? ? ? { msg: "這是第四條信息這是第四條信息這是第四條信息這是第四條信息" },
? ? ? ? { msg: "這是第五條信息這是第五條信息這是第五條信息這是第五條信息" }
? ? ? ],
? ? ? play: false,
? ? ? timer: null, // //接收定時(shí)器
? ? };
? },
? mounted() { ?//頁(yè)面掛載完成時(shí)就開始定時(shí)器,公告文字滾動(dòng)
? ? setInterval(this.startPlay, 4000);
? ? ?console.log('開始定時(shí)器');
? },
? destroyed() { // 頁(yè)面銷毀時(shí)清除定時(shí)器
? ? clearInterval(this.timer);?
? ? console.log('銷毀定時(shí)器');
? },
? methods: {
? ? startPlay() {
? ? ? let that = this;
? ? ? that.play = true; //開始播放
? ? ? that.timer = setTimeout(() => { ?//創(chuàng)建并執(zhí)行定時(shí)器
? ? ? ? that.ulList.push(that.ulList[0]); //將第一條數(shù)據(jù)塞到最后一個(gè)
? ? ? ? that.ulList.shift(); //刪除第一條數(shù)據(jù)
? ? ? ? that.play = false; //暫停播放
? ? ? }, 500);
? ? ? console.log(that.timer);
? ? },
? }
};

css樣式

<style lang="scss" scoped>
.roll {
? width: 100%;
? height: 60px; /*關(guān)鍵樣式*/
? line-height: 60px; /*關(guān)鍵樣式*/
? background: #fff;
? margin-bottom: 24px;
? box-shadow: 4px 0 10px rgba(226, 226, 226, 0.3);
? padding: 0 20px;
? color: #f5212d;
? font-size: 14px;
? display: flex;
? .roll-line {
? ? width: 2px;
? ? height: 100%;
? ? background: #dee2e6;
? ? margin: 0 20px 0 -20px;
? }
? .el-icon-bell {
? ? color: #343a40;
? ? line-height: 60px; /*關(guān)鍵樣式*/
? ? margin-right: 10px;
? }
? .toUp {
? ? margin-top: -60px; /*關(guān)鍵樣式*/
? ? transition: all 1s; /*關(guān)鍵樣式*/
? }
? .list {
? ? list-style: none;
? ? width: 100%;
? ? text-align: center;
? ? overflow: hidden; /*關(guān)鍵樣式*/
? ? height: 60px; /*關(guān)鍵樣式*/
? ? padding: 0;
? ? margin: 0;
? }
? li {
? ? text-align: left;
? ? height: 60px; /*關(guān)鍵樣式*/
? ? line-height: 60px; /*關(guān)鍵樣式*/
? }
}
</style>

關(guān)于定時(shí)器的清除

由于定時(shí)器在調(diào)用時(shí),都會(huì)返回一個(gè)整形的數(shù)字,該數(shù)字代表定時(shí)器的序號(hào),即第多少個(gè)定時(shí)器,所以定時(shí)器的清除要借助于這個(gè)返回的數(shù)字。
定時(shí)器清除的方法:clearTimeout(obj)和clearInterval(obj)。(注意定時(shí)器的清除方法)

通過打印console.log(that.timer);可以看出確實(shí)會(huì)返回一個(gè)整數(shù),他代表是第幾個(gè)定時(shí)器

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue實(shí)現(xiàn)短信驗(yàn)證碼輸入框

    vue實(shí)現(xiàn)短信驗(yàn)證碼輸入框

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)短信驗(yàn)證碼輸入框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • vue.js實(shí)現(xiàn)左邊導(dǎo)航切換右邊內(nèi)容

    vue.js實(shí)現(xiàn)左邊導(dǎo)航切換右邊內(nèi)容

    這篇文章主要為大家詳細(xì)介紹了vue.js實(shí)現(xiàn)左邊導(dǎo)航切換右邊內(nèi)容,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue3?process.env.XXX環(huán)境變量不生效的解決方法

    vue3?process.env.XXX環(huán)境變量不生效的解決方法

    這篇文章主要給大家介紹了關(guān)于vue3?process.env.XXX環(huán)境變量不生效的解決方法,通過文中介紹的方法可以很方便的解決遇到的問題,對(duì)大家學(xué)習(xí)或者使用vue3具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • vue打包優(yōu)化時(shí)配置webpack的8大方案小結(jié)

    vue打包優(yōu)化時(shí)配置webpack的8大方案小結(jié)

    vue-cli?生成的項(xiàng)目通常集成Webpack?,在打包的時(shí)候,需要webpack來做一些事情,這里我們希望它可以壓縮代碼體積,提高運(yùn)行效率,本文為大家整理了8大webpack配置方案,希望對(duì)大家有所幫助
    2024-02-02
  • Vue之el-option下拉框綁定問題

    Vue之el-option下拉框綁定問題

    這篇文章主要介紹了Vue之el-option下拉框綁定問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue中點(diǎn)擊url下載文件的案例詳解

    Vue中點(diǎn)擊url下載文件的案例詳解

    這篇文章主要介紹了Vue中點(diǎn)擊url下載文件案例詳解,此文需要注意若是文件的url存在跨域的情況,則可能會(huì)下載失敗,因?yàn)閒etch請(qǐng)求連接后,由于跨域,拿不到資源,也就無法執(zhí)行后續(xù)的操作,此時(shí)是失敗的,詳細(xì)內(nèi)容跟隨小編一起看看吧
    2022-04-04
  • Vue+Router+Element實(shí)現(xiàn)簡(jiǎn)易導(dǎo)航欄

    Vue+Router+Element實(shí)現(xiàn)簡(jiǎn)易導(dǎo)航欄

    這篇文章主要為大家詳細(xì)介紹了Vue+Router+Element實(shí)現(xiàn)簡(jiǎn)易導(dǎo)航欄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Vue常用API、高級(jí)API的相關(guān)總結(jié)

    Vue常用API、高級(jí)API的相關(guān)總結(jié)

    這篇文章主要介紹了Vue常用API、高級(jí)API的相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-02-02
  • vue 父組件調(diào)用子組件方法及事件

    vue 父組件調(diào)用子組件方法及事件

    這篇文章主要介紹了vue 父組件調(diào)用子組件方法及事件的相關(guān)資料,父組件傳入數(shù)組子組件循環(huán)來創(chuàng)建不同的組件模塊,所有事件都在子組件內(nèi)部.怎么實(shí)現(xiàn)這樣一個(gè)功能呢?接下來跟隨腳本之家小編一起看看吧
    2018-03-03
  • Vue.js之render函數(shù)使用詳解

    Vue.js之render函數(shù)使用詳解

    這篇文章主要介紹了Vue.js之render函數(shù)使用詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09

最新評(píng)論