vue.js使用过程中的一些笔记

watch列表中immediatetrue时,监听回调将在beforeCreatecreated生命周期之间执行。如需在此监听回调中访问子组件或DOM元素,请使用this.$nextTick()

慎用beforeUpdateupdated生命周期钩子函数,尤其不能在此类生命周期函数中对data中的数据进行更改,否则极易导致死循环和浏览器崩溃(不断触发beforeUpdateupdated生命周期,并一直往microtask队列中放入任务)。如果必须在此类生命周期中对data中的数据进行修改,可以考虑在setTimeout()中进行相关操作(相关操作将被放到macrotask中,一般不会导致浏览器完全卡死)。如果数据被渲染到DOM中且变动频繁,则beforeUpdateupdated生命周期钩子函数也会被频繁调用,易造成性能下降问题。

组件刚加载时,render函数在beforeMountmounted之间执行,之后每次在数据发生更新时都会被执行,在beforeUpdateupdated之间执行。

SSR模式下,服务端在执行完beforeCreatecreated生命周期钩子函数后会直接执行render函数生成页面的内容。

当data中被改变的变量在模板中被用到,或在渲染函数中被访问到时,才会触发组件的重新渲染,以及beforeUpdateupdate生命周期。

关于组件间传值: