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

Vue?transition組件簡(jiǎn)單實(shí)現(xiàn)數(shù)字滾動(dòng)

 更新時(shí)間:2022年09月22日 11:12:25   作者:田八  
這篇文章主要為大家介紹了Vue?transition組件簡(jiǎn)單實(shí)現(xiàn)數(shù)字滾動(dòng)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

實(shí)現(xiàn)效果

Scrip

<template>
  <button @click="addCount">點(diǎn)我滾動(dòng)數(shù)字</button>
  <div class="roll-container">
    <transition name="roll">
      <div class="roll-number" :key="count">{{ count }}</div>
    </transition>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';
export default defineComponent({
  setup() {
    const count = ref(0);
    let click_time = Date.now();
    function addCount() {
      if (Date.now() - click_time < 300) return;
      click_time = Date.now();
      count.value += 1;
    }
    return {
      count,
      addCount,
    };
  },
});
</script>
<style>
.roll-container {
  position: relative;
  text-align: center;
  font-size: 120px;
  line-height: 1em;
  color: #fff;
  height: 1em;
  min-width: 1em;
  max-width: 3em;
  background: #000000;
  overflow: hidden;
}
.roll-number {
  /* position: absolute; */
  /* top: 0; */
  width: 100%;
}
.roll-enter-active,
.roll-leave-active {
  transition: all .3s;
  position: absolute;
  top: 0;
}
.roll-leave-to {
  top: -1em;
}
.roll-enter-active {
  top: 1em;
}
.roll-enter-to {
  top: 0;
}
</style>
      

使用vuetransition組件,來(lái)實(shí)現(xiàn)一個(gè)數(shù)字滾動(dòng)效果,其實(shí)不僅可以是數(shù)字滾動(dòng),還可以是文字、段落滾動(dòng),代碼片段使用了定位做的,還可以使用transform,只是一種思路,不限制方案。

布局

沒(méi)有別人寫(xiě)的東西炫酷,我都不知道怎么寫(xiě)內(nèi)容了,布局沒(méi)啥好講的,我這里會(huì)有一個(gè)容器包裹內(nèi)部滾動(dòng)的數(shù)字,主要是用于隱藏內(nèi)部滾動(dòng)的數(shù)字超出的部分,代碼如下:

  <div class="roll-container">
    <transition name="roll">
      <div class="roll-number" :key="count">{{ count }}</div>
    </transition>
  </div>

樣式如下:

.roll-container {
  position: relative;
  text-align: center;
  font-size: 120px;
  line-height: 1em;
  color: #fff;
  height: 1em;
  min-width: 1em;
  max-width: 3em;
  background: #000000;
  overflow: hidden;
}
.roll-number {
  width: 100%;
}

這里的細(xì)節(jié)就是transition組件是用于元素顯隱狀態(tài)切換使用的,一般用于v-ifv-show,還有transition-group也是一樣的,不過(guò)transition-group是用于多個(gè)元素上的,可以作用在列表上,對(duì)于列表的數(shù)據(jù)新增、刪除可以觸發(fā)過(guò)渡效果。

而我這里使用keykey發(fā)生改變可以強(qiáng)制元素的更新,可以完整的觸發(fā)組件的生命周期,就達(dá)到了元素銷(xiāo)毀和創(chuàng)建的整個(gè)過(guò)程,也可以觸發(fā)過(guò)渡,key的作用老生常談了,可以網(wǎng)上去查查資料,用得好可以有很多巧妙的作用。

動(dòng)畫(huà)

動(dòng)畫(huà)是使用vuetransition組件的css class過(guò)渡方式,官網(wǎng)上的文檔過(guò)渡的生命周期描述的很清楚,我就不搬運(yùn)了,vue transiton組件

過(guò)渡css代碼:

/* 
動(dòng)畫(huà)激活時(shí)給予初始狀態(tài),這個(gè)基礎(chǔ)狀態(tài)用于定義后續(xù)過(guò)渡動(dòng)作的起點(diǎn)
這里統(tǒng)一定義了組件創(chuàng)建和組件銷(xiāo)毀的兩個(gè)起點(diǎn),主要是賦予 transition 使其有一個(gè)過(guò)渡
*/
.roll-enter-active,
.roll-leave-active {
  transition: all .3s;
  position: absolute;
  top: 0;
}
/* 
組件銷(xiāo)毀,過(guò)渡的終點(diǎn)
最開(kāi)始的起點(diǎn)是原位,離開(kāi)的時(shí)候滾到上面去
*/
.roll-leave-to {
  top: -1em;
}
/*
組件創(chuàng)建,過(guò)渡的起點(diǎn)
創(chuàng)建的時(shí)候是重下往上進(jìn)入,所以元素最開(kāi)始是在下面
*/
.roll-enter-active {
  top: 1em;
}
/*
過(guò)渡的時(shí)候回到起點(diǎn),達(dá)到重下往上滾動(dòng)
*/
.roll-enter-to {
  top: 0;
}

代碼就這么一丟丟,只要理解了過(guò)渡的生命周期,就可以控制各種效果,我這里這個(gè)應(yīng)該是入門(mén)級(jí)代碼,這里的細(xì)節(jié)就是需要定義一個(gè)過(guò)渡的起點(diǎn),因?yàn)槭褂玫氖嵌ㄎ唬绻辉O(shè)置起點(diǎn)是沒(méi)有過(guò)渡效果的,如果是用變換(transform)可以不用設(shè)置起點(diǎn),為什么這個(gè)就和css相關(guān)了,不在這次的談?wù)摲秶畠?nèi)。

邏輯控制

邏輯控制主要是要?jiǎng)赢?huà)執(zhí)行完成之后才能再次修改變量,否則就會(huì)有重疊,閃動(dòng)等,造成動(dòng)畫(huà)不連貫,我這里動(dòng)畫(huà)執(zhí)行時(shí)間是300毫秒,所以也就是300毫秒只能修改一次狀態(tài)。

    const count = ref(0);
    // 緩存第一次狀態(tài)修改的時(shí)間
    let click_time = Date.now();
    function addCount() {
      // 300ms 只能執(zhí)行一次
      if (Date.now() - click_time < 300) return;
      // 重置狀態(tài)修改的時(shí)間
      click_time = Date.now();
      count.value += 1;
    }

這個(gè)就是一個(gè)很簡(jiǎn)單的邏輯控制,這里是通過(guò)點(diǎn)擊來(lái)修改的,這里也可以通過(guò)定時(shí)器去處理。

總結(jié)

以前要做一個(gè)數(shù)字滾動(dòng)需要弄一個(gè)插件,插件代碼也多,通過(guò)js進(jìn)行控制處理,一般都是把0-9的數(shù)字放一排,然后滾動(dòng),滾動(dòng)完成把頭部的數(shù)字放到尾部,而使用transition組件只要這么一丟丟代碼就可以完成相同的功能,如果在加上vue3新出的css變量綁定,還可以做到過(guò)渡動(dòng)畫(huà)執(zhí)行時(shí)間的動(dòng)態(tài)控制。

以上就是Vue transition組件簡(jiǎn)單實(shí)現(xiàn)數(shù)字滾動(dòng)的詳細(xì)內(nèi)容,更多關(guān)于Vue transition數(shù)字滾動(dòng)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue項(xiàng)目如何在js文件里獲取路由參數(shù)及路由跳轉(zhuǎn)

    Vue項(xiàng)目如何在js文件里獲取路由參數(shù)及路由跳轉(zhuǎn)

    日常業(yè)務(wù)中路由跳轉(zhuǎn)的同時(shí)傳遞參數(shù)是比較常見(jiàn)的,下面這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目如何在js文件里獲取路由參數(shù)及路由跳轉(zhuǎn)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • vue3在router中使用store報(bào)錯(cuò)的完美解決方案

    vue3在router中使用store報(bào)錯(cuò)的完美解決方案

    這篇文章主要介紹了vue3在router中使用store報(bào)錯(cuò)解決方案,就是需要在實(shí)例化一下,因?yàn)樵诰幾grouter的時(shí)候pinia還未被實(shí)例化,文中補(bǔ)充介紹了vue3中router和store詳細(xì)使用教程方法,感興趣的朋友一起看看吧
    2023-11-11
  • Vue filter格式化時(shí)間戳?xí)r間成標(biāo)準(zhǔn)日期格式的方法

    Vue filter格式化時(shí)間戳?xí)r間成標(biāo)準(zhǔn)日期格式的方法

    今天小編就為大家分享一篇Vue filter格式化時(shí)間戳?xí)r間成標(biāo)準(zhǔn)日期格式的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue element-ui el-tooltip組件失效問(wèn)題及解決

    vue element-ui el-tooltip組件失效問(wèn)題及解決

    這篇文章主要介紹了vue element-ui el-tooltip組件失效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 解決webpack+Vue引入iView找不到字體文件的問(wèn)題

    解決webpack+Vue引入iView找不到字體文件的問(wèn)題

    今天小編就為大家分享一篇解決webpack+Vue引入iView找不到字體文件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue 登錄滑動(dòng)驗(yàn)證實(shí)現(xiàn)代碼

    vue 登錄滑動(dòng)驗(yàn)證實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue 登錄滑動(dòng)驗(yàn)證實(shí)現(xiàn)代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-08-08
  • vue實(shí)現(xiàn)2048小游戲功能思路詳解

    vue實(shí)現(xiàn)2048小游戲功能思路詳解

    這篇文章主要介紹了vue實(shí)現(xiàn)2048小游戲功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • 使用vant的地域控件追加全部選項(xiàng)

    使用vant的地域控件追加全部選項(xiàng)

    這篇文章主要介紹了使用vant的地域控件追加全部選項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • 某些場(chǎng)景下建議vue query代替pinia原理解析

    某些場(chǎng)景下建議vue query代替pinia原理解析

    這篇文章主要為大家介紹了某些場(chǎng)景下建議vue-query代替pinia原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Vue項(xiàng)目中引入字體文件的幾種方法總結(jié)

    Vue項(xiàng)目中引入字體文件的幾種方法總結(jié)

    在 Vue 項(xiàng)目中引入自定義字體文件,可以通過(guò)多種方式實(shí)現(xiàn),這取決于你的項(xiàng)目結(jié)構(gòu)、構(gòu)建工具以及字體文件的來(lái)源,本文將詳細(xì)介紹如何通過(guò)不同方法引入本地字體文件以及從外部引入字體,需要的朋友可以參考下
    2024-10-10

最新評(píng)論