vue轉react useEffect的全過程
vue轉react useEffect
useEffect用于處理組件中的effect,通常用于請求數(shù)據(jù),事件處理,訂閱等相關操作。
useEffect的第二個參數(shù)
1.當useEffect沒有第二個參數(shù)時


通過這個例子可以看到useEffect沒有第二個參數(shù)時不停的在調用
2.當useEffect第二個參數(shù)為空數(shù)組時


通過這個例子可以看出來useEffect在調用一次后就不再調用
3.當useEffect第二個參數(shù)為變量時

通過這個例子可以看出來useEffect在每次count發(fā)生變化時調用
useEffect的使用

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

useEffect通過return進行一些清除。

例如官方文檔里面的例子,當props.friend.id發(fā)生變化時,可以進行清除工作
vue2轉戰(zhàn)React Hooks實踐
從vue2轉戰(zhàn)到react16.12, 還是有好多差異的。總結起來:
開發(fā)思路上
vue是基于data的雙向綁定,數(shù)據(jù)流在model(data)<=>view(template)中是雙向流動關系。所以修改data, 綁定該data的視圖會隨之修改;修改view,data中的數(shù)據(jù)也會隨之修改(當然,這種情況只針對于可輸入類型的表單元素),然后再配合鉤子函數(shù)created、mount、activated、deactivated、beforeDestroy(還有vue-router提供的beforeRouteLeave等)等在某個時刻自動觸發(fā)一些業(yè)務邏輯。
react(16.8版本后,官方推薦react hooks開發(fā)方式)則是單向數(shù)據(jù)流動,通過useState聲明變量,視圖綁定state。類似鉤子函數(shù)的工作,react使用useEffect來實現(xiàn),通過不同的依賴項,實現(xiàn)不同的鉤子函數(shù)作用。react開發(fā)上,就像堆積木,開發(fā)的所有東西都是組件,所以組件化更徹底;vue則是以page劃分的,然后組件是引入到page中的。
代碼組織結構上
vue是以.vue為模塊組織代碼的,一個.vue模塊中包含template、script、style來分別實現(xiàn)視圖、業(yè)務邏輯、樣式的編寫。
react是以.jsx為模塊組織代碼的,一個.jsx模塊中template都是嵌入在script中的,style另外引入,更像是所有代碼都是在函數(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;
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
el-select 下拉框多選實現(xiàn)全選的實現(xiàn)
這篇文章主要介紹了el-select 下拉框多選實現(xiàn)全選的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08
Vue中import與@import的區(qū)別及使用場景說明
這篇文章主要介紹了Vue中import與@import的區(qū)別及使用場景說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
vue響應式更新機制及不使用框架實現(xiàn)簡單的數(shù)據(jù)雙向綁定問題
vue是一款具有響應式更新機制的框架,既可以實現(xiàn)單向數(shù)據(jù)流也可以實現(xiàn)數(shù)據(jù)的雙向綁定。這篇文章主要介紹了vue響應式更新機制及不使用框架實現(xiàn)簡單的數(shù)據(jù)雙向綁定問題,需要的朋友可以參考下2019-06-06
vue3 elementPlus 表格實現(xiàn)行列拖拽及列檢索功能(完整代碼)
本文通過實例代碼給大家介紹vue3 elementPlus 表格實現(xiàn)行列拖拽及列檢索功能,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-10-10
vue select二級聯(lián)動第二級默認選中第一個option值的實例
下面小編就為大家分享一篇vue select二級聯(lián)動第二級默認選中第一個option值的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘Combin
這篇文章主要介紹了vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09

