vue和react生命周期之间有何区别?(对比)

本篇文章给大家带来的内容是关于vue和react生命周期之间有何区别?(对比),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

 vue的生命周期如下图所示(很清晰)初始化、编译、更新、销毁

 vue和react生命周期之间有何区别?(对比)

二 vue生命周期的栗子

 注意触发vue的created事件以后,this便指向vue实例,这点很重要

立即学习“前端免费学习笔记(深入)”;

                    vue生命周期                                
{{a}}
我是内容二
var myVue = new Vue({ el: ".test", data: { a: "我是内容,在控制台输入myVue.a=123456,可以改变我的值" }, created: function () { //在实例创建之后同步调用。此时实例已经结束解析选项,这意味着已建立:数据绑定,计算属性,方法,watcher/事件回调。 //但是还没有开始 DOM 编译,$el 还不存在,但是实例存在,即this.a存在,可打印出来 。 console.log("建立"); }, beforeCompile: function () { console.log("未开始编译"); }, compiled: function () { //在编译结束后调用。此时所有的指令已生效,因而数据的变化将触发 DOM 更新。但是不担保 $el 已插入文档。 console.log("编译完成"); }, ready: function () { //在编译结束和 $el 第一次插入文档之后调用,如在第一次 attached 钩子之后调用。注意必须是由 Vue 插入(如 vm.$appendTo() 等方法或指令更新)才触发 ready 钩子。 console.log("一切准备好了"); }, attached :function () { //myVue.$appendTo(".test2")暂时触发不了,不知道怎么解决 //在 vm.$el 插入 DOM 时调用。必须是由指令或实例方法(如 $appendTo())插入,直接操作 vm.$el 不会 触发这个钩子。 console.log("插入DOM成功"); }, detached :function () { //触发事件 myVue.$destroy(true),其中参数true控制是否删除DOM节点或者myVue.$remove() //在 vm.$el 从 DOM 中删除时调用。必须是由指令或实例方法删除,直接操作 vm.$el 不会 触发这个钩子。 console.log("删除DOM成功"); }, beforeDestroy: function () { //触发方式,在console里面打myVue.$destroy(); //在开始销毁实例时调用。此时实例仍然有功能。 console.log("销毁前"); }, destroyed: function () { //触发方式,在console里面打myVue.$destroy();其中myVue.$destroy(true)是删除DOM节点,会触发detached函数,但是实例仍然存在 //在实例被销毁之后调用。此时所有的绑定和实例的指令已经解绑,注意是解绑不是销毁,所有的子实例也已经被销毁。 console.log("已销毁"); } });

登录后复制

一、react生命周期

React 生命周期分为三种状态 1. 初始化 2.更新 3.销毁588767-20161205190022429-1074951616.jpg

初始化

1、getDefaultProps()

设置默认的props,也可以用ufaultProps设置组件的默认属性.

2、getInitialState()

在使用es6的class语法时是没有这个钩子函数的,可以直接在constructor中定义this.state。此时可以访问this.props

3、componentWillMount()

组件初始化时只调用,以后组件更新不调用,整个生命周期只调用一次,此时可以修改state。

4、 render()

react最重要的步骤,创建虚拟dom,进行diff算法,更新dom树都在此进行。此时就不能更改state了。

5、componentDidMount()

组件渲染之后调用,只调用一次。

更新

6、componentWillReceiveProps(nextProps)

组件初始化时不调用,组件接受新的props时调用。

7、shouldComponentUpdate(nextProps, nextState)

react性能优化非常重要的一环。组件接受新的state或者props时调用,我们可以设置在此对比前后两个props和state是否相同,如果相同则返回false阻止更新,因为相同的属性状态一定会生成相同的dom树,这样就不需要创造新的dom树和旧的dom树进行diff算法对比,节省大量性能,尤其是在dom结构复杂的时候

8、componentWillUpdata(nextProps, nextState)

组件初始化时不调用,只有在组件将要更新时才调用,此时可以修改state

9、render()

组件渲染

10、componentDidUpdate()

组件初始化时不调用,组件更新完成后调用,此时可以获取dom节点。

卸载

11、componentWillUnmount()

组件将要卸载时调用,一些事件监听和定时器需要在此时清除。

以上就是vue和react生命周期之间有何区别?(对比)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2740240.html

(0)
上一篇 2025年3月8日 02:14:36
下一篇 2025年3月8日 02:14:40

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • react生命周期介绍

    导语: 如果我们要学习react,那么了解生命周期是必不可少的。我们在了解过生命周期的各个组件后,对写高性能组件会有很大的帮助。 (学习视频分享:react视频教程) Ract生命周期 React 生命周期分为三种状态 1. 初始化 2.更…

    2025年3月7日
    200
  • 浅谈Angular中组件的生命周期

    本篇文章给大家介绍一下angular中组件的生命周期(component lifecycle hook)。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 环境:Angular CLI: 11.0.6Angular: 11.…

    2025年3月7日
    200
  • Angular学习之聊聊生命周期

    本篇文章带大家继续angular的学习,使用angular进行开发时,避免不了需要接触生命周期,下面就来带大家一起聊聊angular中的生命周期,希望对大家有所帮助! 接触过 react 和 vue 开发的读者应该对生命周期这个概念不陌生。…

    2025年3月7日 编程技术
    200
  • Servlet 容器揭秘:深入了解 Servlet 运行环境

    php小编百草为您揭秘Servlet容器,带您深入了解Servlet的运行环境。Servlet容器是一种用于部署和运行Servlet的环境,负责管理Servlet生命周期、请求处理等。深入了解Servlet容器的工作原理和机制,对于开发高效…

    2025年3月6日
    200
  • 解释C语言中变量的生命周期

    存储类指定变量的范围、生命周期和绑定。 要完整定义变量,不仅需要提及其“类型”,还需要提及其存储类。 变量名称标识计算机内存中的某个物理位置,其中分配了一组位来存储变量的值。 存储类别告诉我们以下因素 – 变量存储在哪里(内存或…

    2025年3月6日
    200
  • 如何处理 C++ 函数指针的析构和生命周期管理?

    在 c++++ 中,函数指针需要适当的析构和生命周期管理。可以通过以下方式实现:手动析构函数指针,释放内存。使用智能指针,如 std::unique_ptr 或 std::shared_ptr,自动管理函数指针的生命周期。将函数指针绑定到对…

    2025年3月6日
    200
  • 如何在 Go 中管理 Goroutine 的生命周期?

    go 中管理 goroutine 生命周期的核心方法如下:使用 context.context:通过取消信号和截止日期控制 goroutine 生命周期。使用 sync.waitgroup:等待 goroutine 完成任务,以便主 gor…

    2025年3月6日
    200
  • 深入讲解Java编程中类的生命周期

    引言        最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大多只是告诉你“怎样做”,但至于“为…

    2025年3月5日
    200
  • C++ 匿名函数与函数对象的生命周期管理

    C++ 匿名函数与函数对象的生命周期管理 简介 匿名函数和函数对象是 C++ 中强大的工具,用于将代码封装成可调用的实体。然而,管理匿名函数和函数对象的生命周期非常重要,以避免悬空指针错误。 匿名函数 立即学习“C++免费学习笔记(深入)”…

    2025年3月3日
    200
  • 微服务架构中如何处理服务的生命周期和管理?

    随着互联网和移动互联网的快速发展,软件开发变得越来越复杂,而微服务架构已成为当今软件开发的主流趋势之一。微服务架构是一种将大型应用程序划分为多个小型服务的方法。每个服务都具有特定的业务功能,并且可以独立地进行开发、测试和部署。在这种架构中,…

    编程技术 2025年3月2日
    200

发表回复

登录后才能评论