Vue 3.0 组合式API 模板引用 【Vue3 从零开始】

本文介绍了Vue.js中使用组合式API时如何处理响应式引用和模板引用。通过`ref`在`setup()`中声明并返回,可以在组件初始化后获取DOM元素。在JSX和`v-for`循环中使用`ref`也进行了说明,强调在`v-for`中需使用函数引用进行自定义处理。
摘要由CSDN通过智能技术生成

本节代码示例使用单文件组件的语法

本指南假定你已经阅读了组合式 API 简介响应性基础。如果你不熟悉组合式 API,请先阅读此文章。

在使用组合式 API 时,响应式引用模板引用的概念是统一的。为了获得对模板内元素或组件实例的引用,我们可以像往常一样声明 ref 并从 setup() 返回:

 
  1. <template>
  2. <div ref="root">This is a root element</div>
  3. </template>
  4. <script>
  5. import { ref, onMounted } from 'vue'
  6. export default {
  7. setup() {
  8. const root = ref(null)
  9. onMounted(() => {
  10. // DOM元素将在初始渲染后分配给ref
  11. console.log(root.value) // <div>这是根元素</div>
  12. })
  13. return {
  14. root
  15. }
  16. }
  17. }
  18. </script>

这里我们在渲染上下文中暴露 root,并通过 ref="root",将其绑定到 div 作为其 ref。在虚拟 DOM 补丁算法中,如果 VNode 的 ref 键对应于渲染上下文中的 ref,则 VNode 的相应元素或组件实例将被分配给该 ref 的值。这是在虚拟 DOM 挂载/打补丁过程中执行的,因此模板引用只会在初始渲染之后获得赋值。

作为模板使用的 ref 的行为与任何其他 ref 一样:它们是响应式的,可以传递到 (或从中返回) 复合函数中。

#JSX 中的用法

 
  1. export default {
  2. setup() {
  3. const root = ref(null)
  4. return () =>
  5. h('div', {
  6. ref: root
  7. })
  8. // with JSX
  9. return () => <div ref={root} />
  10. }
  11. }

#v-for 中的用法

组合式 API 模板引用在 v-for 内部使用时没有特殊处理。相反,请使用函数引用执行自定义处理:

 
  1. <template>
  2. <div v-for="(item, i) in list" :ref="el => { if (el) divs[i] = el }">
  3. {{ item }}
  4. </div>
  5. </template>
  6. <script>
  7. import { ref, reactive, onBeforeUpdate } from 'vue'
  8. export default {
  9. setup() {
  10. const list = reactive([1, 2, 3])
  11. const divs = ref([])
  12. // 确保在每次更新之前重置ref
  13. onBeforeUpdate(() => {
  14. divs.value = []
  15. })
  16. return {
  17. list,
  18. divs
  19. }
  20. }
  21. }
  22. </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值