Vue項(xiàng)目中使用setTimeout存在的潛在問(wèn)題及解決
使用setTimeout存在的潛在問(wèn)題
在開(kāi)發(fā)項(xiàng)目中遇到這樣的序曲,點(diǎn)擊按鈕彈框,每次進(jìn)入的時(shí)候都需要默認(rèn)選中Android,
這個(gè)時(shí)候就遇到了一個(gè)小坑,當(dāng)用戶點(diǎn)擊彈框后,選擇iOS,再點(diǎn)擊cancel或者OK,樓主在開(kāi)發(fā)的時(shí)候,點(diǎn)擊cancel按鈕,執(zhí)行下面代碼
this.showDialog = false; // 關(guān)閉彈框 this.createForm.platform = "Android"; // 重置下拉框的默認(rèn)選擇項(xiàng)為Android this.createForm.secureCoreVersion = ""; // 清空輸入框的東西
然后

這幾行代碼在邏輯上看是正確的邏輯,但是實(shí)際頁(yè)面上顯示的樣子,卻不一樣,點(diǎn)擊cancel按鈕的時(shí)候,彈框關(guān)閉,但是彈框會(huì)在關(guān)閉前的一刻,下拉框選中的iOS 會(huì)閃一下,變成Android,體驗(yàn)不是很好,于是,樓主想到了使用setTimeout來(lái)解決問(wèn)題,遂寫成如下代碼
this.showDialog = false;
setTimeout(() => {
this.createForm.platform = "Android";
this.createForm.secureCoreVersion = "";
}, 500);
把 清空彈框里面表單的東西放在了定時(shí)器里面,這樣就能避免在點(diǎn)擊關(guān)閉按鈕的時(shí)候,下拉框選項(xiàng)閃一下,變成默認(rèn)選項(xiàng)Android的問(wèn)題。
但是,過(guò)了1天,有個(gè)同事跑過(guò)來(lái)跟我說(shuō),樓主的寫法存在一定的潛藏風(fēng)險(xiǎn),那就是使用了setTimeout定時(shí)器來(lái)處理這個(gè)問(wèn)題,
他的回答是:
定時(shí)器一般只能用在寫動(dòng)畫里面,日常的業(yè)務(wù)邏輯層代碼盡量不要使用定時(shí)器,因?yàn)槎〞r(shí)器雖然表面上能解決這個(gè)問(wèn)題,但是,如果用戶在設(shè)置的500毫秒以內(nèi)再次點(diǎn)擊cancel按鈕,就會(huì)出現(xiàn)問(wèn)題,定時(shí)器的原理實(shí)際上就是把js執(zhí)行的這段代碼拿到一個(gè)宏任務(wù)里面,最后執(zhí)行
于是乎,p7水平的同事,跟我這樣說(shuō),可以換一種思路,
可以在點(diǎn)擊彈框彈出來(lái)的時(shí)候把彈框里面的選項(xiàng)都進(jìn)行重置,不需要在關(guān)閉彈框的時(shí)候進(jìn)行重置,其實(shí)是一個(gè)逆向思維的問(wèn)題,在一開(kāi)始點(diǎn)擊彈框打開(kāi)的時(shí)候直接重置參數(shù),這樣就能巧妙的繞過(guò)在關(guān)閉彈框出現(xiàn)的問(wèn)題通過(guò)elementUI dialog 組件自帶的 closed 回調(diào)函數(shù)來(lái)解決問(wèn)題

elementUI 的官網(wǎng)里面關(guān)于dialog彈框,封裝了在關(guān)閉動(dòng)畫結(jié)束時(shí)執(zhí)行的回調(diào)函數(shù),直接在這個(gè)回調(diào)函數(shù)里面執(zhí)行重置選項(xiàng)的邏輯就好了
上代碼


最后樓主采用的是第二種方法來(lái)解決閃現(xiàn)的問(wèn)題的
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue如何實(shí)現(xiàn)簡(jiǎn)易的彈出框
這篇文章主要介紹了vue如何實(shí)現(xiàn)簡(jiǎn)易的彈出框,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
詳解關(guān)于element級(jí)聯(lián)選擇器數(shù)據(jù)回顯問(wèn)題
這篇文章主要介紹了詳解關(guān)于element級(jí)聯(lián)選擇器數(shù)據(jù)回顯問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-02-02
Vue + OpenLayers 快速入門學(xué)習(xí)教程
大家都知道使用 Openlayers可以很靈活自由的做出各種地圖和空間數(shù)據(jù)的展示。而且這個(gè)框架是完全免費(fèi)和開(kāi)源的,本文記錄下 Vue 使用 OpenLayers 入門,使用 OpenLayers 創(chuàng)建地圖組件的相關(guān)知識(shí),需要的朋友一起學(xué)習(xí)下吧2021-09-09
Vue 3 + Element Plus樹(shù)形表格全選多選及子節(jié)點(diǎn)勾選的問(wèn)題解決方
在本文中,我們解決了Vue 3和Element Plus樹(shù)形表格中的全選、多選、子節(jié)點(diǎn)勾選和父節(jié)點(diǎn)勾選等常見(jiàn)問(wèn)題,通過(guò)逐步實(shí)現(xiàn)這些功能,您可以構(gòu)建功能強(qiáng)大且用戶友好的樹(shù)形表格組件,以滿足各種數(shù)據(jù)展示需求,對(duì)Vue 3 Element Plus樹(shù)形表格相關(guān)知識(shí)感興趣的朋友一起看看吧2023-12-12
vue引入iconfont圖標(biāo)庫(kù)的優(yōu)雅實(shí)戰(zhàn)記錄
使用組件庫(kù)時(shí),圖標(biāo)往往不能滿足需求,所以我們常常需要用到第三方圖標(biāo)庫(kù),這篇文章主要給大家介紹了關(guān)于vue引入iconfont的相關(guān)資料,需要的朋友可以參考下2021-06-06
vue項(xiàng)目環(huán)境搭建?啟動(dòng)?移植操作示例及目錄結(jié)構(gòu)分析
這篇文章主要介紹了vue項(xiàng)目環(huán)境搭建、啟動(dòng)、項(xiàng)目移植、項(xiàng)目目錄結(jié)構(gòu)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04
vue項(xiàng)目中使用ueditor的實(shí)例講解
下面小編就為大家分享一篇vue項(xiàng)目中使用ueditor的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03

