亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue轉(zhuǎn)react useEffect的全過程

 更新時間:2022年09月14日 11:47:48   作者:亦曉寒  
這篇文章主要介紹了vue轉(zhuǎn)react useEffect的全過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue轉(zhuǎn)react useEffect

useEffect用于處理組件中的effect,通常用于請求數(shù)據(jù),事件處理,訂閱等相關(guān)操作。

useEffect的第二個參數(shù)

1.當(dāng)useEffect沒有第二個參數(shù)時

通過這個例子可以看到useEffect沒有第二個參數(shù)時不停的在調(diào)用

2.當(dāng)useEffect第二個參數(shù)為空數(shù)組時

通過這個例子可以看出來useEffect在調(diào)用一次后就不再調(diào)用

3.當(dāng)useEffect第二個參數(shù)為變量時

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

useEffect的使用

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

useEffect清除

useEffect通過return進行一些清除。

例如官方文檔里面的例子,當(dāng)props.friend.id發(fā)生變化時,可以進行清除工作

vue2轉(zhuǎn)戰(zhàn)React Hooks實踐

從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等)等在某個時刻自動觸發(fā)一些業(yè)務(wù)邏輯。

react(16.8版本后,官方推薦react hooks開發(fā)方式)則是單向數(shù)據(jù)流動,通過useState聲明變量,視圖綁定state。類似鉤子函數(shù)的工作,react使用useEffect來實現(xiàn),通過不同的依賴項,實現(xiàn)不同的鉤子函數(shù)作用。react開發(fā)上,就像堆積木,開發(fā)的所有東西都是組件,所以組件化更徹底;vue則是以page劃分的,然后組件是引入到page中的。

代碼組織結(jié)構(gòu)上

vue是以.vue為模塊組織代碼的,一個.vue模塊中包含template、script、style來分別實現(xiàn)視圖、業(yè)務(wù)邏輯、樣式的編寫。

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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • el-select 下拉框多選實現(xiàn)全選的實現(xiàn)

    el-select 下拉框多選實現(xiàn)全選的實現(xiàn)

    這篇文章主要介紹了el-select 下拉框多選實現(xiàn)全選的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Vue?仿QQ左滑刪除組件功能

    Vue?仿QQ左滑刪除組件功能

    前幾天朋友在做vue項目開發(fā)時,有人反映?IOS?上面的滑動點擊有點問題,讓我們來幫忙解決,于是我就重寫了代碼,下面把vue仿qq左滑刪除組件功能分享到腳本之家平臺,需要的朋友參考下吧
    2018-03-03
  • Vue中import與@import的區(qū)別及使用場景說明

    Vue中import與@import的區(qū)別及使用場景說明

    這篇文章主要介紹了Vue中import與@import的區(qū)別及使用場景說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue響應(yīng)式更新機制及不使用框架實現(xiàn)簡單的數(shù)據(jù)雙向綁定問題

    vue響應(yīng)式更新機制及不使用框架實現(xiàn)簡單的數(shù)據(jù)雙向綁定問題

    vue是一款具有響應(yīng)式更新機制的框架,既可以實現(xiàn)單向數(shù)據(jù)流也可以實現(xiàn)數(shù)據(jù)的雙向綁定。這篇文章主要介紹了vue響應(yīng)式更新機制及不使用框架實現(xiàn)簡單的數(shù)據(jù)雙向綁定問題,需要的朋友可以參考下
    2019-06-06
  • 如何在寶塔面板部署vue項目

    如何在寶塔面板部署vue項目

    這篇文章主要給大家介紹了關(guān)于如何在寶塔面板部署vue項目的相關(guān)資料,寶塔面板可以通過Nginx來部署Vue項目,并解決跨域問題,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • vue環(huán)境搭建簡單教程

    vue環(huán)境搭建簡單教程

    這篇文章主要介紹了vue環(huán)境搭建簡單教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • vue3 elementPlus 表格實現(xiàn)行列拖拽及列檢索功能(完整代碼)

    vue3 elementPlus 表格實現(xiàn)行列拖拽及列檢索功能(完整代碼)

    本文通過實例代碼給大家介紹vue3 elementPlus 表格實現(xiàn)行列拖拽及列檢索功能,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-10-10
  • vue select二級聯(lián)動第二級默認(rèn)選中第一個option值的實例

    vue select二級聯(lián)動第二級默認(rèn)選中第一個option值的實例

    下面小編就為大家分享一篇vue select二級聯(lián)動第二級默認(rèn)選中第一個option值的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案

    IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案

    ios密碼框輸入密碼光標(biāo)離開之后會提示存儲密碼的彈窗,關(guān)于這樣的問題怎么解決呢,下面給大家分享IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案,感興趣的朋友一起看看吧
    2024-07-07
  • vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)

    vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘Combin

    這篇文章主要介紹了vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09

最新評論