vue轉(zhuǎn)react useEffect的全過(guò)程
vue轉(zhuǎn)react useEffect
useEffect用于處理組件中的effect,通常用于請(qǐng)求數(shù)據(jù),事件處理,訂閱等相關(guān)操作。
useEffect的第二個(gè)參數(shù)
1.當(dāng)useEffect沒(méi)有第二個(gè)參數(shù)時(shí)


通過(guò)這個(gè)例子可以看到useEffect沒(méi)有第二個(gè)參數(shù)時(shí)不停的在調(diào)用
2.當(dāng)useEffect第二個(gè)參數(shù)為空數(shù)組時(shí)


通過(guò)這個(gè)例子可以看出來(lái)useEffect在調(diào)用一次后就不再調(diào)用
3.當(dāng)useEffect第二個(gè)參數(shù)為變量時(shí)

通過(guò)這個(gè)例子可以看出來(lái)useEffect在每次count發(fā)生變化時(shí)調(diào)用
useEffect的使用

上面的例子可以看出來(lái)使用useEffect和和class component使用生命周期函數(shù)時(shí)的區(qū)別,使用useEffect將每次count變化的數(shù)據(jù)都打印出來(lái),而使用componentDidUpdate打印了最后一個(gè)數(shù)據(jù)很多次,因?yàn)閏lass component里面的state隨著render是發(fā)生變化的,而useEffect里面的所有東西都是每次render獨(dú)立的。
useEffect清除

useEffect通過(guò)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é)起來(lái):
開(kāi)發(fā)思路上
vue是基于data的雙向綁定,數(shù)據(jù)流在model(data)<=>view(template)中是雙向流動(dòng)關(guān)系。所以修改data, 綁定該data的視圖會(huì)隨之修改;修改view,data中的數(shù)據(jù)也會(huì)隨之修改(當(dāng)然,這種情況只針對(duì)于可輸入類型的表單元素),然后再配合鉤子函數(shù)created、mount、activated、deactivated、beforeDestroy(還有vue-router提供的beforeRouteLeave等)等在某個(gè)時(shí)刻自動(dòng)觸發(fā)一些業(yè)務(wù)邏輯。
react(16.8版本后,官方推薦react hooks開(kāi)發(fā)方式)則是單向數(shù)據(jù)流動(dòng),通過(guò)useState聲明變量,視圖綁定state。類似鉤子函數(shù)的工作,react使用useEffect來(lái)實(shí)現(xiàn),通過(guò)不同的依賴項(xiàng),實(shí)現(xiàn)不同的鉤子函數(shù)作用。react開(kāi)發(fā)上,就像堆積木,開(kāi)發(fā)的所有東西都是組件,所以組件化更徹底;vue則是以page劃分的,然后組件是引入到page中的。
代碼組織結(jié)構(gòu)上
vue是以.vue為模塊組織代碼的,一個(gè).vue模塊中包含template、script、style來(lái)分別實(shí)現(xiàn)視圖、業(yè)務(wù)邏輯、樣式的編寫(xiě)。
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();
}, []);
// 請(qǐng)求數(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)文章
vue實(shí)現(xiàn)動(dòng)態(tài)添加元素(可刪除)
文章介紹了如何在Vue中動(dòng)態(tài)添加和刪除元素,通過(guò)使用Vue的響應(yīng)式數(shù)據(jù)和v-for指令,可以輕松地實(shí)現(xiàn)這一功能,文章還詳細(xì)講解了如何處理元素的添加和刪除事件,以及如何更新視圖以反映這些變化2024-12-12
vue + el-tree 實(shí)現(xiàn)插入節(jié)點(diǎn)自定義名稱數(shù)據(jù)的代碼
這篇文章主要介紹了vue + el-tree 實(shí)現(xiàn)插入節(jié)點(diǎn)自定義名稱數(shù)據(jù)的代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12
vue3修改link標(biāo)簽?zāi)J(rèn)icon無(wú)效問(wèn)題詳解
這篇文章主要介紹了vue3修改link標(biāo)簽?zāi)J(rèn)icon無(wú)效問(wèn)題詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
vue單頁(yè)面改造多頁(yè)面應(yīng)用的全過(guò)程記錄
眾所都知vue是一個(gè)單頁(yè)面應(yīng)用,下面這篇文章主要給大家介紹了關(guān)于vue單頁(yè)面改造多頁(yè)面應(yīng)用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05

