useEffect理解React、Vue设计理念的不同

 更新时间:2022年09月20日 14:46:28   作者:魔术师卡颂  
这篇文章主要为大家介绍了useEffect理解React、Vue设计理念的不同详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

我们知道,React发布Hooks后,带来了业界一波Hooks热。很多框架(比如Vue Composition APISolid.js)都借鉴了Hooks的模式。

但是,即使这些框架都借鉴了Hooks,但由于框架作者的理念不同,发展方向也逐渐不同。

比如,在Vue Composition API中,对标React useEffect API的是watchEffect,在Vue文档中,有一小段内容介绍他的用法:

而在React beta文档中,介绍useEffect的,则有整整6节内容:

为什么会有这样的区别?让我们从useEffect看看ReactVue设计理念的不同。

Vue与React的差异

Hooks刚问世时,他被看作是类组件的替代方案。文档中介绍Hooks时也是将他与类组件对比。

其中useEffect的执行时机囊括了如下3个生命周期函数:

componentDidMount

componentDidUpdate

componentWillUnmount

反观借鉴了HooksVue Composition API,则同时提供了watchEffect API与不同场景的生命周期函数。

这里已经体现出两者设计理念的不同了:

React作为Facebook为探索UI开发最佳实践而生的框架,一贯的做法是 —— 保持API稳定(比如this.setStateReact诞生伊始就一直存在)。

Vue则借鉴了各种框架中的最佳实践(比如虚拟DOM、响应式更新...)。

所以,从易用性上来说,Vue Composition API是一定优于React Hooks的,比如:

Hooks不能在条件语句中声明

Hooks必须显式指明依赖

并且,这种易用性的差异会随着框架迭代,愈发明显。

useEffect会越来越复杂

本着保持API稳定的原则,当前useEffect主要与上述三个生命周期函数相关。

但是,未来会有更多触发时机与useEffect挂钩。

所以,React团队在努力做一件事 —— 淡化useEffect与生命周期的关系,甚至淡化useEffect与组件的关系(因为当谈到组件时,很自然的会想到组件生命周期)。

怎么淡化呢?答案是 —— 在严格模式下,DEV环境会触发多次useEffect回调。

如果你将useEffect当作componentDidMount/WillUnmount来用,这个特性很可能让你的代码出bug

React团队之所以这么做,就是想教育开发者 —— useEffect和生命周期没有关系。开发者应该将useEffect看作针对某个数据源的同步过程

比如,下述聊天室组件,其中的useEffect可以看作是针对聊天室连接的同步过程

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

当聊天室组件mountupdateunmount时,对应的同步过程应该进行。

roomId变化时,对应的同步过程应该进行。

同理,如果React原生支持了Vue中的KeepAlive,那么当聊天室组件从可见变为不可见,以及从不可见变为可见状态,同步过程都应该进行。

所以,当我们从同步过程应该何时进行的角度看待useEffect时,上述useEffect触发时机都是合理的。

但是,如果从生命周期函数的角度看待useEffect,等未来(可能是v18的某个版本),Offscreen Component特性落地(对标Vue中的KeepAlive),组件从可见变为不可见状态时,useEffect销毁函数useEffect回调函数会依次执行,就会让人很头大。

这就是为什么,我上文说,React团队一直在淡化useEffect与生命周期的关系,甚至淡化useEffect与组件的关系。

一切都是为了未来其他特性与useEffect的挂钩打下理论基础。而这些特性从组件生命周期函数的角度讲不通。

这也是为什么在新文档里有6节内容与useEffect相关的原因。

作为对比,Vue在遇到新的场景时会怎么做呢?显然是设计新的API

总结

到底是提供一个API,但是能覆盖更多场景(文档有6节来介绍他)好,还是每个场景都提供一个API好?

不同开发者有自己的答案。

但有一点很明确,对于前端新手,React的上手难度会越来越高,而Vue的上手难度会尽可能保持平滑。

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

所以,对于当前的从业者来说,这究竟是好事还是坏事呢?

以上就是useEffect理解React、Vue设计理念的不同的详细内容,更多关于useEffect React Vue设计理念的资料请关注脚本之家其它相关文章!

相关文章

  • axios进阶实践之利用最优雅的方式写ajax请求

    axios进阶实践之利用最优雅的方式写ajax请求

    之前给大家介绍了jQuery利用最优雅的方式写ajax请求的相关内容,这篇文章主要给大家介绍了关于axios进阶实践之利用最优雅的方式写ajax请求的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-12-12
  • 用vue快速开发app的脚手架工具

    用vue快速开发app的脚手架工具

    这篇文章主要介绍了用vue快速开发app的脚手架工具,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 使用vue.js实现联动效果的示例代码

    使用vue.js实现联动效果的示例代码

    本篇文章主要介绍了使用vue.js实现联动效果的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 浅谈VUE uni-app 自定义组件

    浅谈VUE uni-app 自定义组件

    这篇文章主要介绍了uni-app 的自定义组件,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-10-10
  • vuecli4中如何配置打包使用相对路径

    vuecli4中如何配置打包使用相对路径

    这篇文章主要介绍了vuecli4中如何配置打包使用相对路径,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Vue生态的新成员Pinia的详细介绍

    Vue生态的新成员Pinia的详细介绍

    本文主要介绍了Vue生态的新成员Pinia的详细介绍,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • Vue封装全局toast组件的完整实例

    Vue封装全局toast组件的完整实例

    组件(Component)是 Vue.js 最强大的功能之一,组件可以扩展 HTML 元素,封装可重用的代码,这篇文章主要给大家介绍了关于Vue封装全局toast组件,需要的朋友可以参考下
    2021-07-07
  • vue中node_modules中第三方模块的修改使用详解

    vue中node_modules中第三方模块的修改使用详解

    这篇文章主要介绍了vue中node_modules中第三方模块的修改使用,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • vue实现将自己网站(h5链接)分享到微信中形成小卡片的超详细教程

    vue实现将自己网站(h5链接)分享到微信中形成小卡片的超详细教程

    在微信小程序中,可以很简单的分享一个页面,比微信H5简单多了,下面这篇文章主要给大家介绍了关于vue实现将自己网站(h5链接)分享到微信中形成小卡片的超详细教程,需要的朋友可以参考下
    2023-02-02
  • vue中过滤器filter的讲解

    vue中过滤器filter的讲解

    今天小编就为大家分享一篇关于vue中过滤器filter的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01

最新评论