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

Vue3+Hooks實現(xiàn)4位隨機數(shù)和60秒倒計時的示例代碼

 更新時間:2024年04月14日 15:48:54   作者:帥龍之龍  
Vue3的Hooks是一種新的 API,本文主要介紹了Vue3+Hooks實現(xiàn)4位隨機數(shù)和60秒倒計時的示例代碼,具有一定的參考價值,感興趣的可以了解一下

前言

首先,Vue3的Hooks是一種新的 API,用于在Vue組件中管理狀態(tài)和生命周期。它們是基于 React Hooks的概念設(shè)計的,可以讓開發(fā)者更方便地在函數(shù)式組件中使用狀態(tài)管理和生命周期函數(shù)。本文給大家分享一下基于Hooks實現(xiàn)的兩個案例。

一、示例代碼

(1)/src/views/HelloWorld.vue

<template>
  <div class="index">
    <h1>{{ code }}</h1>
    <p>
      <el-input size="small" style="font-size: 13px" placeholder="請輸入驗證碼" />
      <el-button size="small" :disabled="isDisabled" @click="sendCode">{{ countdownText }}</el-button>
    </p>
    <p>{{ `disabled=${isDisabled}` }}</p>
  </div>
</template>

<script lang='ts' setup>
import { useRandomCode } from '@/hooks/useRandomCode'
const code = useRandomCode()
import useCountDown from '@/hooks/useCountDown'
const { countdownText, isDisabled, sendCode } = useCountDown(60)
</script>

<style lang="less" scoped>
.index {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  overflow: hidden;
  justify-content: center;
  align-items: center;

  p {
    display: flex;
    flex-direction: row;
    align-items: center;
  }
}
</style>

(2)/src/hooks/useRandomCode.js

import { ref, onMounted, onBeforeUnmount, onUnmounted } from 'vue'

/**
 * 4位隨機數(shù)
 */
export const useRandomCode = () => {

  const code = ref(('000' + Math.floor(Math.random() * 10000)).slice(-4))

  const fn = () => {
    let num = Math.floor(Math.random() * 10000)
    num = ('000' + num).slice(-4)
    return num
  }

  setInterval(() => {
    code.value = fn()
  }, 1000)

  onMounted(() => {
    console.log('useRandomCode -> onMounted')
  })

  onBeforeUnmount(() => {
    console.log('useRandomCode -> onBeforeUnmount')
  })

  onUnmounted(() => {
    console.log('useRandomCode -> onUnmounted')
  })

  return code
}

(3)/src/hooks/useCountDown.ts

import { ref, Ref, onMounted, onBeforeUnmount, onUnmounted } from 'vue'
 
/**
 * 60秒倒計時
 */
export default (num: number, text = '發(fā)送驗證碼'): ({ countdownText: Ref<string>, isDisabled: Ref<boolean>, sendCode: () => void }) => {
  const countdownNum = ref(num)
  const countdownText = ref(text)
  const isDisabled = ref(false)
  
  const sendCode = () => {
    countdownText.value = `${countdownNum.value}s`
    isDisabled.value = true
    const timer = setInterval(() => {
      countdownNum.value--
      countdownText.value = `${countdownNum.value}s`
      if (countdownNum.value === 0) {
        clearInterval(timer)
        countdownNum.value = num
        countdownText.value = text
        isDisabled.value = false
      }
    }, 1000)
  }
 
  onMounted(() => {
    console.log('useCountDown -> onMounted')
  })
 
  onBeforeUnmount(() => {
    console.log('useCountDown -> onBeforeUnmount')
  })
 
  onUnmounted(() => {
    console.log('useCountDown -> onUnmounted')
  })
 
  return { countdownText, isDisabled, sendCode }
}

二、運行效果

三、更多了解見以下文章

詳解hooks在vue3中的使用方法及示例_vue.js_腳本之家

最前端|一文詳解Vue3.x 中 hooks 函數(shù)封裝和使用 - 知乎

到此這篇關(guān)于Vue3+Hooks實現(xiàn)4位隨機數(shù)和60秒倒計時的示例代碼的文章就介紹到這了,更多相關(guān)Vue3+Hooks 4位隨機數(shù)和60秒倒計時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何使用sm4js進行加密和國密sm4總結(jié)

    如何使用sm4js進行加密和國密sm4總結(jié)

    近期由于公司項目的需要開始研究國密SM4加密,下面這篇文章主要給大家介紹了關(guān)于如何使用sm4js進行加密和國密sm4的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • Vue結(jié)合leaflet實現(xiàn)克里金插值

    Vue結(jié)合leaflet實現(xiàn)克里金插值

    本文主要介紹了Vue結(jié)合leaflet實現(xiàn)克里金插值,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 深入理解Vue 的鉤子函數(shù)

    深入理解Vue 的鉤子函數(shù)

    這篇文章主要介紹了Vue 的鉤子函數(shù),本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • vue內(nèi)置指令詳解

    vue內(nèi)置指令詳解

    指令是Vue模板中最常用的一項功能,它帶有前綴v-,主要職責(zé)是當(dāng)其表達式的值改變時,相應(yīng)的將某些行為應(yīng)用在 DOM 上。這篇文章主要介紹了vue內(nèi)置指令詳解,需要的朋友可以參考下
    2018-04-04
  • Vue實現(xiàn)拖放排序功能的實例代碼

    Vue實現(xiàn)拖放排序功能的實例代碼

    本文通過實例代碼給大家介紹了Vue中實現(xiàn)拖放排序功能,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • 詳解Vue.use自定義自己的全局組件

    詳解Vue.use自定義自己的全局組件

    本篇文章主要介紹了Vue.use自定義自己的全局組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 全面解析vue中的數(shù)據(jù)雙向綁定

    全面解析vue中的數(shù)據(jù)雙向綁定

    這篇文章主要介紹了vue中的數(shù)據(jù)雙向綁定問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫

    Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫

    這篇文章主要為大家詳細介紹了Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Vue3?路由頁面切換動畫?animate.css效果

    Vue3?路由頁面切換動畫?animate.css效果

    這篇文章主要介紹了Vue3路由頁面切換動畫animate.css效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • vue如何統(tǒng)一樣式(reset.css與border.css)

    vue如何統(tǒng)一樣式(reset.css與border.css)

    這篇文章主要介紹了vue如何統(tǒng)一樣式(reset.css與border.css),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論