React倒計(jì)時(shí)功能實(shí)現(xiàn)代碼——解耦通用
需求分析
需求
在某個(gè)頁(yè)面中需要有一個(gè)倒計(jì)時(shí)的功能,倒計(jì)時(shí) 5 s,5s鐘后跳轉(zhuǎn)到新的界面
分析
- 首先是實(shí)現(xiàn)倒計(jì)時(shí)功能
- 其次是實(shí)現(xiàn)在每倒計(jì)時(shí) 1 s后頁(yè)面上要執(zhí)行 倒計(jì)時(shí)秒數(shù)變化的功能
- 最后是實(shí)現(xiàn)倒計(jì)時(shí)完成后 跳轉(zhuǎn)到指定頁(yè)面的功能
初版做法
代碼
let waitTime = 5
class DemoPage extends React.Component {
constructor(props) {
super(props);
this.state = {
time: '',
};
}
componentDidMount = () => {
this.countDown();
};
countDown = () => {
if (waitTime > 0) {
waitTime--;
this.setState({
time:waitTime
})
} else {
history.push('/Login')
return;
}
setTimeout(() => {
this.countDown();
}, 1000);
}
render() {
todoInfo = this.state.time + '秒后跳轉(zhuǎn)至登錄界面';
return (
<div>
todoInfo
</div>
);
}
}
export default DemoPage;
問(wèn)題分析
時(shí)間設(shè)置為全局變量,糟糕的做法,
- 修改不方便
- 難于閱讀和理解
- 全局變量的值極不安全,可能被任何程序修改
改進(jìn)版
代碼
class DemoPage extends React.Component {
constructor(props) {
super(props);
this.state = {
time: '',
};
}
componentDidMount = () => {
this.countDown(5);//倒計(jì)時(shí)時(shí)間可隨意調(diào)整,且可讀性強(qiáng)
};
countDown = (waitTime) => {
if (waitTime > 0) {
waitTime--;
this.setState({
time:waitTime
})
} else {
history.push('/Login')
return;
}
setTimeout(() => {
this.countDown(waitTime);
}, 1000);
}
render() {
todoInfo = this.state.time + '秒后跳轉(zhuǎn)至登錄界面';
return (
<div>
todoInfo
</div>
);
}
}
export default DemoPage;
改進(jìn)后將時(shí)間作為參數(shù)放到countDown里面,方便隨意設(shè)置倒計(jì)時(shí)時(shí)間
進(jìn)一步分析問(wèn)題:
上面的做法,
- setState的操作只能寫在本組件,與本組件緊耦合在一起,無(wú)法實(shí)現(xiàn)多組件復(fù)用
- history.push('/Login') 只能用在umi 框架中,與框架緊耦合在一起,無(wú)法實(shí)現(xiàn)普適應(yīng)用
進(jìn)一步改進(jìn)
針對(duì)本問(wèn)題的需求,可以將業(yè)務(wù)場(chǎng)景擴(kuò)大為:
- 倒計(jì)時(shí)功能
- 倒計(jì)時(shí)過(guò)程中 需要做某事
doSomethingDuringCountDown() - 倒計(jì)時(shí)結(jié)束后 需要做某事
doSomethingAfterCountDown()
這樣的話,倒計(jì)時(shí)的功能就可以使用的更加的靈活了。
方案
將函數(shù)作為參數(shù)傳遞到countDown()方法中
將 doSomethingDuringCountDown() 和 doSomethingAfterCountDown()作為參數(shù)傳遞到countDown方法中,
具體的方法實(shí)現(xiàn),根據(jù)自己頁(yè)面的需求來(lái)實(shí)現(xiàn)。
代碼
//utils.js
export countDown = (waitTime,doSomethingDuringCountDown,doSomethingAfterCountDown){
if (waitTime > 0) {
waitTime--;
if(doSomethingDuringCountDown){
doSomethingDuringCountDown()
}
} else {
if(doSomethingAfterCountDown){
doSomethingAfterCountDown()
}
return;
}
setTimeout(() => {
countDown(waitTime,doSomethingDuringCountDown,doSomethingAfterCountDown);
}, 1000);
}
實(shí)例
//DemoPage.jsx
import { countDown } from 'utils.js'
class DemoPage extends React.Component {
constructor(props) {
super(props);
this.state = {
time: '',
};
}
componentDidMount = () => {
countDown(5,this.waitTimeStateChange,this.linkTo);
}
waitTimeStateChange = (time) => {
this.setState({
time: time,
})
}
linkTo = () => {
history.push(ToBeReviewedShowData.linkUrl)
}
render() {
todoInfo = this.state.time + '秒后跳轉(zhuǎn)至登錄界面'
return (
<div>
todoInfo
</div>
)
}
}
export default DemoPage
總結(jié)
到此這篇關(guān)于React倒計(jì)時(shí)功能實(shí)現(xiàn)——解耦通用的文章就介紹到這了,更多相關(guān)React倒計(jì)時(shí)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 基于vue、react實(shí)現(xiàn)倒計(jì)時(shí)效果
- 使用react render props實(shí)現(xiàn)倒計(jì)時(shí)的示例代碼
- React注冊(cè)倒計(jì)時(shí)功能的實(shí)現(xiàn)
- React Native驗(yàn)證碼倒計(jì)時(shí)工具類分享
- react native中的聊天氣泡及timer封裝成的發(fā)送驗(yàn)證碼倒計(jì)時(shí)
- ReactNative短信驗(yàn)證碼倒計(jì)時(shí)控件的實(shí)現(xiàn)代碼
- React-Native中使用驗(yàn)證碼倒計(jì)時(shí)的按鈕實(shí)例代碼
相關(guān)文章
React?Fiber構(gòu)建completeWork源碼解析
這篇文章主要為大家介紹了React?Fiber構(gòu)建completeWork源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
Electron整合React使用搭建開發(fā)環(huán)境的步驟詳解
這篇文章主要介紹了Electron整合React使用搭建開發(fā)環(huán)境,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2020-06-06
React使用fullpage.js實(shí)現(xiàn)整屏翻頁(yè)功能
最近筆者在完成一個(gè)移動(dòng)端小項(xiàng)目的過(guò)程中需要實(shí)現(xiàn)整屏翻頁(yè)的效果;調(diào)研完畢之后,最終決定使用pullPage.js實(shí)現(xiàn)此功能,fullPage.js使用起來(lái)比較方便,并且官網(wǎng)上也給了在react項(xiàng)目中使用的demo,本文記錄了這個(gè)第三方庫(kù)的使用過(guò)程,感興趣的朋友可以參考下2023-11-11
React Hook 監(jiān)聽localStorage更新問(wèn)題
這篇文章主要介紹了React Hook 監(jiān)聽localStorage更新問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vite?+?react?+typescript?環(huán)境搭建小白入門教程
這篇文章主要介紹了vite?+?react?+typescript?環(huán)境搭建小白入門教程,本文通過(guò)示例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
利用React實(shí)現(xiàn)一個(gè)有點(diǎn)意思的電梯小程序
這篇文章主要為大家詳解介紹了如何利用React實(shí)現(xiàn)一個(gè)有點(diǎn)意思的電梯小程序,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2022-08-08

