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

Vue3實現(xiàn)獲取驗證碼按鈕倒計時效果

 更新時間:2024年10月28日 08:54:24   作者:永恒之月℡  
這篇文章主要介紹了Vue3實現(xiàn)獲取驗證碼按鈕倒計時效果,用戶點擊獲取驗證碼按鈕,發(fā)送請求給后端,按鈕失效,并且開始倒計時60秒;在此期間,用戶無法再次點擊按鈕,即使用戶刷新頁面,倒計時依然存在,直到倒計時完畢,按鈕恢復(fù),感興趣的小伙伴跟著小編一起來看看吧

Vue3實現(xiàn)獲取驗證碼按鈕倒計時效果

效果描述:用戶點擊獲取驗證碼按鈕,發(fā)送請求給后端,按鈕失效,并且開始倒計時60秒;在此期間,用戶無法再次點擊按鈕,即使用戶刷新頁面,倒計時依然存在,直到倒計時完畢,按鈕恢復(fù)。效果圖如下:

實現(xiàn)思路和具體實現(xiàn)

實現(xiàn)思路:

  • 通過響應(yīng)式變量來,設(shè)置倒計時默認數(shù)據(jù)(按鈕名稱,秒數(shù),按鈕狀態(tài))
  • 倒計時函數(shù),來改變響應(yīng)式變量里的數(shù)據(jù),使用周期函數(shù)(window.setInterval),來循環(huán)執(zhí)行。
  • 使用watch函數(shù)來監(jiān)控響應(yīng)式變量里的數(shù)據(jù),是否改變,改變就將數(shù)據(jù)保存到LocalStorage中。
  • 使用生命周期函數(shù)onMounted來獲取LocalStorage里面的數(shù)據(jù),防止用戶刷新。
  • 最后,將數(shù)據(jù)和函數(shù),綁定到按鈕上。

具體實現(xiàn):

注意:為了簡潔明了,代碼里只有一個輸入框、按鈕和最重要的邏輯,沒有樣式。用了 element-plus框架,可自行修改。

<template>
	<div>
  <el-input v-model="input" style="width: 125px;margin-right: 10px;" placeholder="請輸入驗證碼" />
   <el-button type="primary" :disabled="countdownInfo.isDisabled" @click="countdown() " style="width:105px;">{{ countdownInfo.buttonName }}</el-button>
	</div>
</template>


<script setup>
    import { ElMessage } from 'element-plus';
	import { ref,watch,onMounted } from 'vue';

      //倒計時信息
    const countdownInfo = ref({
    second: 60,    //倒計時秒
    buttonName: "獲取驗證碼", //按鈕名稱
    isDisabled: false        //按鈕是否有效,默認有效
   })  
    
    //生命周期函數(shù)
    onMounted(() => {
     //獲取localStorage里保存的,倒計時字符串信息,并解析為JSON對象
    var localCountdownInfo = JSON.parse(localStorage.getItem("countdownInfo"));
    //判斷獲取的信息是否為空,為空,說明里面沒有保存數(shù)據(jù),就不賦值到countdownInfo中
    if (localCountdownInfo) {
        countdownInfo.value =localCountdownInfo;
        //不為空時,判斷倒計時秒數(shù),是否為60,不是就直接調(diào)用倒計時函數(shù)(說明沒有倒計時完),執(zhí)行倒計時。
        if (countdownInfo.value.second !== 60) {
            countdown()  //調(diào)用倒計時函數(shù)
        }
    }
})


// 定義倒計時函數(shù)
const countdown=()=> {
    countdownInfo.value.isDisabled = true;   //按鈕無效
            //開始倒計時
            let interval = window.setInterval(function () {
                countdownInfo.value.buttonName =  countdownInfo.value.second + "秒后重新獲取"; //重新設(shè)置按鈕名稱
                countdownInfo.value.second = countdownInfo.value.second - 1;   //倒計時減
                //判斷是否減到了0,為0就恢復(fù)默認信息,并停止倒計時
                if (countdownInfo.value.second <=0) {
                    countdownInfo.value.buttonName = "獲取驗證碼";
                    countdownInfo.value.second = 60;
                    countdownInfo.value.isDisabled = false;
                    window.clearInterval(interval);
                }
            }, 1000);  //一秒執(zhí)行一次

}

//監(jiān)聽對象,數(shù)據(jù)是否發(fā)生改變,改變就進行重新保存
watch(countdownInfo, (newValue) => {
    var JSONSTR = JSON.stringify(newValue);  //將JSON轉(zhuǎn)為字符串
    localStorage.setItem("countdownInfo", JSONSTR)  //將其保存到localStorage中
}, {
    deep: true   //深度監(jiān)聽
})
</script>

到此這篇關(guān)于Vue3實現(xiàn)獲取驗證碼按鈕倒計時效果的文章就介紹到這了,更多相關(guān)Vue3驗證碼按鈕倒計時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue中進行打包與部署的方法實例

    Vue中進行打包與部署的方法實例

    這篇文章主要給大家介紹了關(guān)于Vue中進行打包與部署的相關(guān)資料, 我們常使用前后端分離項目時,會需要將前端vue打包然后部署,需要的朋友可以參考下
    2023-09-09
  • 在Vue2中v-model和.sync區(qū)別解析

    在Vue2中v-model和.sync區(qū)別解析

    在vue2中提供了.sync修飾符,但是在vue3中不再支持.sync,取而代之的是v-model,本文給大家介紹在Vue2中v-model和.sync區(qū)別,感興趣的朋友一起看看吧
    2023-10-10
  • Vue3之Mixin的使用方式(全局,局部,setup內(nèi)部使用)

    Vue3之Mixin的使用方式(全局,局部,setup內(nèi)部使用)

    這篇文章主要介紹了Vue3之Mixin的使用方式(全局,局部,setup內(nèi)部使用),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue+elementUI配置表格的列顯示與隱藏

    vue+elementUI配置表格的列顯示與隱藏

    這篇文章主要為大家詳細介紹了vue+elementUI配置表格的列顯示與隱藏,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue實現(xiàn)圖書管理小案例

    Vue實現(xiàn)圖書管理小案例

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)圖書管理小案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Vue3中的常見組件通信之props和自定義事件詳解

    Vue3中的常見組件通信之props和自定義事件詳解

    這篇文章主要介紹了Vue3中的常見組件通信之props和自定義事件,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • Vue 實現(xiàn)輸入框新增搜索歷史記錄功能

    Vue 實現(xiàn)輸入框新增搜索歷史記錄功能

    這篇文章主要介紹了Vue 輸入框新增搜索歷史記錄功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Vue自定義名稱下載PDF的方法

    Vue自定義名稱下載PDF的方法

    這篇文章主要介紹了Vue自定義名稱下載PDF,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • Vue中如何實現(xiàn)輪播圖的示例代碼

    Vue中如何實現(xiàn)輪播圖的示例代碼

    本篇文章主要介紹了Vue中如何實現(xiàn)輪播圖的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 詳解hooks在vue3中的使用方法及示例

    詳解hooks在vue3中的使用方法及示例

    hooks可以通過特定的函數(shù)將邏輯 "鉤入" 組件中,使得開發(fā)者能夠更靈活地構(gòu)建和管理組件的功能從而提高代碼的可讀性以及可維護性等,本篇文章將介紹hooks如何在vue3中使用以及它的一些實際使用例子,讓大家能更好的了解和使用hooks,需要的朋友可以參考下
    2023-09-09

最新評論