《vue3基础知识》学习笔记Day31-(Period2)组合式API——生命周期钩子和依赖注入

生命周期钩子1.2.3.4.5.6钩子函数在服务器端渲染期间不会被调用。

1.onMounted()

注册一个回调函数,在组件挂载完成后执行

2.onUpdated()

注册一个回调函数,在组件因为响应式状态变更而更新其DOM树之后调用

如果你需要在某个特定的状态更改后访问更新后的 DOM,请使用 nextTick() 作为替代

3.onUnmounted()

注册一个回调函数,在组件实例被卸载之后调用

4.onBeforeMount()

注册一个钩子,在组件被挂载之前被调用。

5.onBeforeUpdated()

注册一个钩子,在组件即将因为响应式状态变更而更新DOM树之前调用

6.onBeforeUnmount()

注册一个钩子,在组件实例被卸载之前调用

7.onErrorCaptured()

注册一个钩子,在捕捉了后代组件传递的错误时调用

错误可以从以下几个来源中捕获:

  • 组件渲染
  • 事件处理器
  • 生命周期钩子
  • setup() 函数
  • 侦听器
  • 自定义指令钩子
  • 过渡钩子

    依赖注入  

 1.provide() 提供一个值,可以被后代组件注入。 

<script setup>
import { ref, provide } from 'vue'
import { fooSymbol } from './injectionSymbols'

// 提供静态值
provide('foo', 'bar')

// 提供响应式的值
const count = ref(0)
provide('count', count)

// 提供时将 Symbol 作为 key
provide(fooSymbol, count)
</script>

2.inject() 注入一个由祖先组件或整个应用(通过app.provide())提供的值

使用方式:假设有一个父组件已经提供了一些值,如前面 provide() 的例子中所示

<script setup>
import { inject } from 'vue'
import { fooSymbol } from './injectionSymbols'

// 注入值的默认方式
const foo = inject('foo')

// 注入响应式的值
const count = inject('count')

// 通过 Symbol 类型的 key 注入
const foo2 = inject(fooSymbol)

// 注入一个值,若为空则使用提供的默认值
const bar = inject('foo', 'default value')

// 注入一个值,若为空则使用提供的工厂函数
const baz = inject('foo', () => new Map())

// 注入时为了表明提供的默认值是个函数,需要传入第三个参数
const fn = inject('function', () => {}, false)
</script>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值