关于Vue3中$refs的两种使用方式

前提条件:子组件必须暴露出可以调用的方法,父组件才能调用

方式一:使用ref()实现

父组件代码示例

<script setup>
import Children from "./Children.vue";
import {ref} from "vue";

// 注意名称要和子组件声明的 ref="childRef" 名称一致
const childRef = ref(null);

function click1() {
  // 调用子组件的方法
  childRef.value.say()
}
</script>

<template>
  <el-container>
    <el-main>

      <el-form inline>
        <el-form-item>
          <el-button type="primary" @click="click1">父调子方式一</el-button>
        </el-form-item>
      </el-form>

      <!-- 子组件 -->
      <children ref="childRef"/>

    </el-main>
  </el-container>
</template>

<style scoped>
</style>

方式二:使用getCurrentInstance()实现

父组件代码示例

<script setup>
import Children from "./Children.vue";
import {getCurrentInstance} from "vue";

// 引入proxy代替vue2中的this
const {proxy} = getCurrentInstance();

function click2() {
  // 调用子组件的open方法
  proxy.$refs.childRef.open()
}
</script>

<template>
  <el-container>
    <el-main>

      <el-form inline>
        <el-form-item>
          <el-button type="primary" @click="click2">父调子方式二</el-button>
        </el-form-item>
      </el-form>

      <!-- 子组件 -->
      <children ref="childRef"/>

    </el-main>
  </el-container>
</template>

<style scoped>
</style>

子组件代码示例

<script setup>
import {ElMessage, ElNotification} from 'element-plus'

const open = () => {
  ElNotification({
    title: '提示',
    message: '这是一个通知!',
  })
}

const say = () => {
  ElMessage({
    type: 'success',
    message: '这是一个弹框!',
    showClose: true,
  })
}

// 注意:子组件必须暴露方法,父组件才能调用成功
defineExpose({open, say})

</script>

<template>
  <el-container>
    <el-main>

      <el-card style="width: 100%;height: 450px">
        <h1>我是子组件</h1>

        <el-button plain @click="say">提示框</el-button>
        <el-button plain @click="open">通知框</el-button>
      </el-card>

    </el-main>
  </el-container>
</template>

<style scoped>
</style>

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风与尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值