最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vue(一):Vue的生命周期以及场景应用

    正文概述 掘金(Arnbit1on)   2021-02-02   867

      Vue的生命周期可以说是最基本的知识之一也是老生常谈的话题了,虽然很基础但是面试和平时使用中总是少不了它,这里我想根据我自己平时学习和工作中对Vue生命周期的理解和应用来做一个总结。

    先附上一张官方文档的图: Vue(一):Vue的生命周期以及场景应用

    生命周期钩子

    1. beforeCreate()

      • 状态:this已经指向了实例,但是并不能访问实例中的诸如data、methods、computed等属性或者方法。
      • 实践应用:常用于初始化非响应变量。还可以增加一些loading的动画效果然后在created()的时候移除。
    2. created()

      • 状态:实例创建完之后马上调用,此时已经可以访问data、methods、computed等属性或者方法,但是还未挂载到DOM上,所以还无法访问$refs$el
      • 实践应用:只进行简单的异步请求,因为此时视图还未完全出现,过多的网络请求会导致首屏加载过慢。
    3. beforeMount()

      • 状态:挂载之前被调用,render函数会首次被调用。
    4. mounted()

      • 状态:实例已经挂载到了DOM上,此时可以获取到DOM节点,$refs$el属性都可以访问。需要注意的是子组件并不能保证一定被挂载,如果要确定所有子组件都挂载,需要使用vm.$nextTick()
      • 实践应用:获取虚拟节点(virtual node即VNode)信息和操作。可以开始进行一些初始化数据的操作。
    5. beforeUpdate()

      • 状态:数据更新时调用,发生在虚拟DOM打补丁之前,此时数据已经是最新的数据 但是页面还是旧的页面。
      • 实践应用:在更新前访问DOM,可手动移除事件监听器。
    6. updated()

      • 状态:DOM已经更新,可以进行DOM操作。
      • 实践应用:虽然数据更新以后会调用该方法,但是不要在此函数中操作数据,处理不当会陷入死循环,比如你在此钩子中设置this.isShow = !this.isShow。这个时候会陷入死循环。但是如果在watch方法中做同样的操作,会直接报错:You may have an infinite update loop in watcher with expression "isShow",故而此时更应该使用监听方法watch和计算属性computed进行数据更新的处理。(watchcomputed的介绍在下面补充说明)
    7. beforeDestroy()

      • 状态:实例销毁之前调用,此时实例还完全可用
      • 实践应用:可做一些交互提示,比如:你确认xx吗?。也可以用于销毁定时器、移除事件监听器、解绑全局时间、销毁插件对象等,避免内存泄露。
    8. destroyed()

      • 状态:实例销毁以后调用,对应Vue实例的所有指令都被解绑,所有事件监听器被移除,所有的子实例也被销毁。
    9. activated()

      • 状态keep-alive组件激活时调用。
      • 实践应用:有的时候我们对某些页面做了缓存,从别的页面返回到此页面时,需要手动触发一些接口数据来更新页面,此时就可以在此生命周期内进行。
    10. deactivated()

      • 状态keep-alive组件停用时调用。

    生命周期在其他场景的应用

    • 在使用eventBus总线机制进行非父子页面传值时,也会涉及到生命周期的问题,详情可以看我这篇文章关于Vue eventBus总线传值时的生命周期问题

    • 需要特别说明的是,如果是使用SSR(服务端渲染),有以下生命周期不会被调用

      1. beforeMount()
      2. mounted()
      3. beforeUpdate()
      4. update()
      5. activated()
      6. deactivated()
      7. beforeDestroy()
      8. destroy()

    补充

    • watch

      • 在watch中监听的数据必须是data中已经声明的或者父组件传递过来props中的数据
      • watch中侦听的数据往往是这个数据会影响多个数据,也就是一对多。常见情况就是某一个状态属性的变更。比如用户的身份变更可能会导致显示的页面发生变化。
      • watch没有缓存
      • wtach支持异步
    • computed

      • computed注册对象需要是data中没有注册的,不然会报错The computed property "xxxx" is already defined in data。提示你已经注册过该字段了。
      • 需要computed计算的属性,往往是多个属性影响这一个属性,也就是多对一。常见情况就是一段文字要显示在页面上,但是该字段由多个响应字段拼接而成,,此时就可以使用计算属性
      • computed是有缓存的,如果依赖的数据没有变化,computed中注册的事件不会被触发,比如说如下情况:

        如果a和b都没有变化,那么console.log("computed")语句是不会被打印的,但是如果a和b数值互换了,虽然a+b的值没有变,但是由于两个值都发送了变化,还是会触发计算方法,触发console.log("computed")这行代码。

      computed:{
        c() {
        	console.log("computed")
        	return this.a + this.b
        }
      }
      
      • computed不支持异步。如果computed里面是异步操作无法监听到变化。

    下载网 » Vue(一):Vue的生命周期以及场景应用

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元