我们都知道 React Hook 刮起了函数式编程的旋风,与之对应的,Vue 也在 3.0 借鉴了这种思想。不过Vue 3.0 hook 不在本文的讨论范畴,本文将重点总结一下Vue 2.0的生命周期 Hook。
比如有父组件 Parent 和子组件 Child,如果父组件监听到子组件挂载 mounted 就做一些逻辑处理,常规的写法可能如下:
{% code title="Parent.vue" %}
<Child @mounted="doSomething"/>
{% endcode %}
{% code title="Child.vue" %}
mounted() {
this.$emit("mounted");
}
{% endcode %}
此外,还有一种特别简单的方式,子组件不需要任何处理,只需要在父组件引用的时候通过@hook 来监听即可,代码如下:
<Child @hook:mounted="doSomething" />
<Child @hook:updated="doSomething" />
可以通过一个程序化的侦听器来注册生命周期的绑定
mounted: function () {
var picker = new Pikaday({
field: this.$refs.input,
format: 'YYYY-MM-DD'
})
this.$once('hook:beforeDestroy', function () {
picker.destroy()
})
}