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

React倒計(jì)時(shí)功能實(shí)現(xiàn)代碼——解耦通用

 更新時(shí)間:2020年09月18日 08:27:29   作者:CherishTheYouth  
這篇文章主要介紹了React倒計(jì)時(shí)功能實(shí)現(xiàn)——解耦通用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

需求分析

需求

在某個(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的操作只能寫(xiě)在本組件,與本組件緊耦合在一起,無(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中條件渲染的常見(jiàn)方法總結(jié)

    React中條件渲染的常見(jiàn)方法總結(jié)

    條件渲染在React開(kāi)發(fā)中非常重要的功能,它允許開(kāi)發(fā)人員根據(jù)條件控制渲染的內(nèi)容,在創(chuàng)建動(dòng)態(tài)和交互式用戶(hù)界面方面發(fā)揮著至關(guān)重要的作用,本文總結(jié)了常用的的條件渲染方法,需要的朋友可以參考下
    2024-01-01
  • React?Fiber構(gòu)建completeWork源碼解析

    React?Fiber構(gòu)建completeWork源碼解析

    這篇文章主要為大家介紹了React?Fiber構(gòu)建completeWork源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • 淺談React原生APP更新

    淺談React原生APP更新

    當(dāng)一個(gè)APP在運(yùn)行的時(shí)候, 開(kāi)發(fā)者想要將自己的代碼更新到用戶(hù)的手機(jī)上時(shí), 一般都有兩種方案, 一是熱更新, 二就是APP更新.熱更新暫且不說(shuō),這篇文章就講講 APP 如何更新。
    2021-06-06
  • react+ant.d添加全局loading方式

    react+ant.d添加全局loading方式

    這篇文章主要介紹了react+ant.d添加全局loading方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • React組件的生命周期詳解

    React組件的生命周期詳解

    React是用于構(gòu)建用戶(hù)界面的JavaScript庫(kù)。本文詳細(xì)講解了React的生命周期,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Electron整合React使用搭建開(kāi)發(fā)環(huán)境的步驟詳解

    Electron整合React使用搭建開(kāi)發(fā)環(huán)境的步驟詳解

    這篇文章主要介紹了Electron整合React使用搭建開(kāi)發(fā)環(huán)境,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2020-06-06
  • React使用fullpage.js實(shí)現(xiàn)整屏翻頁(yè)功能

    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)聽(tīng)localStorage更新問(wèn)題

    React Hook 監(jiān)聽(tīng)localStorage更新問(wèn)題

    這篇文章主要介紹了React Hook 監(jiān)聽(tīng)localStorage更新問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vite?+?react?+typescript?環(huán)境搭建小白入門(mén)教程

    vite?+?react?+typescript?環(huán)境搭建小白入門(mén)教程

    這篇文章主要介紹了vite?+?react?+typescript?環(huán)境搭建小白入門(mé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)意思的電梯小程序

    這篇文章主要為大家詳解介紹了如何利用React實(shí)現(xiàn)一個(gè)有點(diǎn)意思的電梯小程序,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2022-08-08

最新評(píng)論