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

useEffect理解React、Vue設(shè)計理念的不同

 更新時間:2022年09月20日 14:46:28   作者:魔術(shù)師卡頌  
這篇文章主要為大家介紹了useEffect理解React、Vue設(shè)計理念的不同詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

引言

我們知道,React發(fā)布Hooks后,帶來了業(yè)界一波Hooks熱。很多框架(比如Vue Composition API、Solid.js)都借鑒了Hooks的模式。

但是,即使這些框架都借鑒了Hooks,但由于框架作者的理念不同,發(fā)展方向也逐漸不同。

比如,在Vue Composition API中,對標(biāo)React useEffect API的是watchEffect,在Vue文檔中,有一小段內(nèi)容介紹他的用法:

而在React beta文檔中,介紹useEffect的,則有整整6節(jié)內(nèi)容:

為什么會有這樣的區(qū)別?讓我們從useEffect看看React、Vue設(shè)計理念的不同。

Vue與React的差異

當(dāng)Hooks剛問世時,他被看作是類組件的替代方案。文檔中介紹Hooks時也是將他與類組件對比。

其中useEffect的執(zhí)行時機(jī)囊括了如下3個生命周期函數(shù):

componentDidMount

componentDidUpdate

componentWillUnmount

反觀借鑒了HooksVue Composition API,則同時提供了watchEffect API與不同場景的生命周期函數(shù)。

這里已經(jīng)體現(xiàn)出兩者設(shè)計理念的不同了:

React作為Facebook為探索UI開發(fā)最佳實踐而生的框架,一貫的做法是 —— 保持API穩(wěn)定(比如this.setStateReact誕生伊始就一直存在)。

Vue則借鑒了各種框架中的最佳實踐(比如虛擬DOM、響應(yīng)式更新...)。

所以,從易用性上來說,Vue Composition API是一定優(yōu)于React Hooks的,比如:

Hooks不能在條件語句中聲明

Hooks必須顯式指明依賴

并且,這種易用性的差異會隨著框架迭代,愈發(fā)明顯。

useEffect會越來越復(fù)雜

本著保持API穩(wěn)定的原則,當(dāng)前useEffect主要與上述三個生命周期函數(shù)相關(guān)。

但是,未來會有更多觸發(fā)時機(jī)與useEffect掛鉤。

所以,React團(tuán)隊在努力做一件事 —— 淡化useEffect與生命周期的關(guān)系,甚至淡化useEffect與組件的關(guān)系(因為當(dāng)談到組件時,很自然的會想到組件生命周期)。

怎么淡化呢?答案是 —— 在嚴(yán)格模式下,DEV環(huán)境會觸發(fā)多次useEffect回調(diào)。

如果你將useEffect當(dāng)作componentDidMount/WillUnmount來用,這個特性很可能讓你的代碼出bug

React團(tuán)隊之所以這么做,就是想教育開發(fā)者 —— useEffect和生命周期沒有關(guān)系。開發(fā)者應(yīng)該將useEffect看作針對某個數(shù)據(jù)源的同步過程。

比如,下述聊天室組件,其中的useEffect可以看作是針對聊天室連接的同步過程

const serverUrl = 'https://localhost:1234';
function ChatRoom({ roomId }) {
  useEffect(() => {
    const connection = createConnection(serverUrl, roomId);
    connection.connect();
    return () => {
      connection.disconnect();
    };
  }, [roomId]);
  // ...
}

當(dāng)聊天室組件mount、update、unmount時,對應(yīng)的同步過程應(yīng)該進(jìn)行。

當(dāng)roomId變化時,對應(yīng)的同步過程應(yīng)該進(jìn)行。

同理,如果React原生支持了Vue中的KeepAlive,那么當(dāng)聊天室組件從可見變?yōu)?strong>不可見,以及從不可見變?yōu)?strong>可見狀態(tài),同步過程都應(yīng)該進(jìn)行。

所以,當(dāng)我們從同步過程應(yīng)該何時進(jìn)行的角度看待useEffect時,上述useEffect觸發(fā)時機(jī)都是合理的。

但是,如果從生命周期函數(shù)的角度看待useEffect,等未來(可能是v18的某個版本),Offscreen Component特性落地(對標(biāo)Vue中的KeepAlive),組件從可見變?yōu)?strong>不可見狀態(tài)時,useEffect銷毀函數(shù)useEffect回調(diào)函數(shù)會依次執(zhí)行,就會讓人很頭大。

這就是為什么,我上文說,React團(tuán)隊一直在淡化useEffect與生命周期的關(guān)系,甚至淡化useEffect與組件的關(guān)系。

一切都是為了未來其他特性與useEffect的掛鉤打下理論基礎(chǔ)。而這些特性從組件生命周期函數(shù)的角度講不通。

這也是為什么在新文檔里有6節(jié)內(nèi)容與useEffect相關(guān)的原因。

作為對比,Vue在遇到新的場景時會怎么做呢?顯然是設(shè)計新的API。

總結(jié)

到底是提供一個API,但是能覆蓋更多場景(文檔有6節(jié)來介紹他)好,還是每個場景都提供一個API好?

不同開發(fā)者有自己的答案。

但有一點很明確,對于前端新手,React的上手難度會越來越高,而Vue的上手難度會盡可能保持平滑。

這里的前端新手,可能是想入行前端的新人,也可能是覺得前端我也能干的后端。

所以,對于當(dāng)前的從業(yè)者來說,這究竟是好事還是壞事呢?

以上就是useEffect理解React、Vue設(shè)計理念的不同的詳細(xì)內(nèi)容,更多關(guān)于useEffect React Vue設(shè)計理念的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • axios進(jìn)階實踐之利用最優(yōu)雅的方式寫ajax請求

    axios進(jìn)階實踐之利用最優(yōu)雅的方式寫ajax請求

    之前給大家介紹了jQuery利用最優(yōu)雅的方式寫ajax請求的相關(guān)內(nèi)容,這篇文章主要給大家介紹了關(guān)于axios進(jìn)階實踐之利用最優(yōu)雅的方式寫ajax請求的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-12-12
  • 用vue快速開發(fā)app的腳手架工具

    用vue快速開發(fā)app的腳手架工具

    這篇文章主要介紹了用vue快速開發(fā)app的腳手架工具,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • 使用vue.js實現(xiàn)聯(lián)動效果的示例代碼

    使用vue.js實現(xiàn)聯(lián)動效果的示例代碼

    本篇文章主要介紹了使用vue.js實現(xiàn)聯(lián)動效果的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 淺談VUE uni-app 自定義組件

    淺談VUE uni-app 自定義組件

    這篇文章主要介紹了uni-app 的自定義組件,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • vuecli4中如何配置打包使用相對路徑

    vuecli4中如何配置打包使用相對路徑

    這篇文章主要介紹了vuecli4中如何配置打包使用相對路徑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue生態(tài)的新成員Pinia的詳細(xì)介紹

    Vue生態(tài)的新成員Pinia的詳細(xì)介紹

    本文主要介紹了Vue生態(tài)的新成員Pinia的詳細(xì)介紹,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Vue封裝全局toast組件的完整實例

    Vue封裝全局toast組件的完整實例

    組件(Component)是 Vue.js 最強(qiáng)大的功能之一,組件可以擴(kuò)展 HTML 元素,封裝可重用的代碼,這篇文章主要給大家介紹了關(guān)于Vue封裝全局toast組件,需要的朋友可以參考下
    2021-07-07
  • vue中node_modules中第三方模塊的修改使用詳解

    vue中node_modules中第三方模塊的修改使用詳解

    這篇文章主要介紹了vue中node_modules中第三方模塊的修改使用,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue實現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程

    vue實現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程

    在微信小程序中,可以很簡單的分享一個頁面,比微信H5簡單多了,下面這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程,需要的朋友可以參考下
    2023-02-02
  • vue中過濾器filter的講解

    vue中過濾器filter的講解

    今天小編就為大家分享一篇關(guān)于vue中過濾器filter的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01

最新評論