vue轉(zhuǎn)react useEffect的全過程
vue轉(zhuǎn)react useEffect
useEffect用于處理組件中的effect,通常用于請求數(shù)據(jù),事件處理,訂閱等相關(guān)操作。
useEffect的第二個(gè)參數(shù)
1.當(dāng)useEffect沒有第二個(gè)參數(shù)時(shí)
通過這個(gè)例子可以看到useEffect沒有第二個(gè)參數(shù)時(shí)不停的在調(diào)用
2.當(dāng)useEffect第二個(gè)參數(shù)為空數(shù)組時(shí)
通過這個(gè)例子可以看出來useEffect在調(diào)用一次后就不再調(diào)用
3.當(dāng)useEffect第二個(gè)參數(shù)為變量時(shí)
通過這個(gè)例子可以看出來useEffect在每次count發(fā)生變化時(shí)調(diào)用
useEffect的使用
上面的例子可以看出來使用useEffect和和class component使用生命周期函數(shù)時(shí)的區(qū)別,使用useEffect將每次count變化的數(shù)據(jù)都打印出來,而使用componentDidUpdate打印了最后一個(gè)數(shù)據(jù)很多次,因?yàn)閏lass component里面的state隨著render是發(fā)生變化的,而useEffect里面的所有東西都是每次render獨(dú)立的。
useEffect清除
useEffect通過return進(jìn)行一些清除。
例如官方文檔里面的例子,當(dāng)props.friend.id發(fā)生變化時(shí),可以進(jìn)行清除工作
vue2轉(zhuǎn)戰(zhàn)React Hooks實(shí)踐
從vue2轉(zhuǎn)戰(zhàn)到react16.12, 還是有好多差異的??偨Y(jié)起來:
開發(fā)思路上
vue是基于data的雙向綁定,數(shù)據(jù)流在model(data)<=>view(template)中是雙向流動關(guān)系。所以修改data, 綁定該data的視圖會隨之修改;修改view,data中的數(shù)據(jù)也會隨之修改(當(dāng)然,這種情況只針對于可輸入類型的表單元素),然后再配合鉤子函數(shù)created、mount、activated、deactivated、beforeDestroy(還有vue-router提供的beforeRouteLeave等)等在某個(gè)時(shí)刻自動觸發(fā)一些業(yè)務(wù)邏輯。
react(16.8版本后,官方推薦react hooks開發(fā)方式)則是單向數(shù)據(jù)流動,通過useState聲明變量,視圖綁定state。類似鉤子函數(shù)的工作,react使用useEffect來實(shí)現(xiàn),通過不同的依賴項(xiàng),實(shí)現(xiàn)不同的鉤子函數(shù)作用。react開發(fā)上,就像堆積木,開發(fā)的所有東西都是組件,所以組件化更徹底;vue則是以page劃分的,然后組件是引入到page中的。
代碼組織結(jié)構(gòu)上
vue是以.vue為模塊組織代碼的,一個(gè).vue模塊中包含template、script、style來分別實(shí)現(xiàn)視圖、業(yè)務(wù)邏輯、樣式的編寫。
react是以.jsx為模塊組織代碼的,一個(gè).jsx模塊中template都是嵌入在script中的,style另外引入,更像是所有代碼都是在函數(shù)中實(shí)現(xiàn)的。
import React, { useState, useEffect, useCallback } from 'react'; import style from './index.less'; import CardTest from '../components/CardTest/index'; import { getInfo } from '../../../api/api'; const CardTest = () => { const [info, setInfo] = useState({}); useEffect(() => { requestData(); }, []); // 請求數(shù)據(jù) const requestData = () => { const requestParm = "XXX"; getInfo(requestParm) .then(res => { const { data = {} } = res; setInfo(data); }) .catch(err => {}); }; return ( <div className={style.wrap}> <div className="list"> <CardTest data={info} /> </div> </div> ); }; export default CardTest;
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
el-select 下拉框多選實(shí)現(xiàn)全選的實(shí)現(xiàn)
這篇文章主要介紹了el-select 下拉框多選實(shí)現(xiàn)全選的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Vue中import與@import的區(qū)別及使用場景說明
這篇文章主要介紹了Vue中import與@import的區(qū)別及使用場景說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06vue響應(yīng)式更新機(jī)制及不使用框架實(shí)現(xiàn)簡單的數(shù)據(jù)雙向綁定問題
vue是一款具有響應(yīng)式更新機(jī)制的框架,既可以實(shí)現(xiàn)單向數(shù)據(jù)流也可以實(shí)現(xiàn)數(shù)據(jù)的雙向綁定。這篇文章主要介紹了vue響應(yīng)式更新機(jī)制及不使用框架實(shí)現(xiàn)簡單的數(shù)據(jù)雙向綁定問題,需要的朋友可以參考下2019-06-06vue3 elementPlus 表格實(shí)現(xiàn)行列拖拽及列檢索功能(完整代碼)
本文通過實(shí)例代碼給大家介紹vue3 elementPlus 表格實(shí)現(xiàn)行列拖拽及列檢索功能,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-10-10vue select二級聯(lián)動第二級默認(rèn)選中第一個(gè)option值的實(shí)例
下面小編就為大家分享一篇vue select二級聯(lián)動第二級默認(rèn)選中第一個(gè)option值的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案
ios密碼框輸入密碼光標(biāo)離開之后會提示存儲密碼的彈窗,關(guān)于這樣的問題怎么解決呢,下面給大家分享IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案,感興趣的朋友一起看看吧2024-07-07vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘Combin
這篇文章主要介紹了vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09