vue3父子组件传参以及父组件调用子组件的属性或方法

本文介绍了Vue中父子组件之间的数据传递,重点讲解了如何使用v-bind、defineProps、props类型声明(包括TS中的可选类型和默认值)、ref以及如何通过defineExpose暴露子组件的属性和方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 父组件通过v-bind(或者属性绑定)绑定一个数据,传递字符串类型是不需要v-bind, 传递非字符串类型时候可以通过 冒号简写

//  父组件
<template>
  <Son ref="sonRef" title="晚上好" :arr="[1,2,3]"></Son>
</template>

2 子组件通过defineProps接收,defineProps是无须引入的直接使用即可,下面这种写法是没有默认值

//  子组件
<template>
  <div>我是父组件传过来的title------{{title}}</div>
   <div>我是父组件传过来的arr------{{arr}}</div>
</template>
<script lang="ts" setup>
import {reactive, ref} from "vue";

// 这里的ref也可以用reactive,如果使用reactive传递值的时候就不用list.value了
const list = ref<number[]>([7,8,9])  
// 通过type声明Props
type Props = {
    title?: string, // ?表示可选
    arr?: number[],
}

// 1 ts第一种写法,但是这种写法是没默认值的
 defineProps<{
    title: string,
    arr: number[],
 }>()
</script>

3 下面这种方式也是通过defineProps接收,但是这种写法是有默认值的,是ts中特有的写法

//  子组件
<template>
  <div>我是父组件传过来的title------{{title}}</div>
   <div>我是父组件传过来的arr------{{arr}}</div>
</template>
<script lang="ts" setup>
import {reactive, ref} from "vue";

const list = ref<number[]>([7,8,9])
// 1 可以使用type声明Props
type Props = {
    title?: string, // ?表示可选
    arr?: number[],
}

// 2 ts第二种写法,withDefaults是ts中特有的,是有默认值的
withDefaults(defineProps<Props>(),{
    title: '默认值',
    arr: () => [],
})
</script>

4 刚才子组件中使用的是type声明Props,也可以使用下面这种方式去声明

interface Props  {
    title?: string,
    arr?: number[],
}

5 如果在js中,子组件中defineProps是下面这种写法

defineProps({
     title:{
        type: String,
        default: '',
     },
    arr:{
        type: Array,
        default: [],
     }
 })

6 在父组件中接收

// 父组件
<template>
  <Son  @send="sonSend"></Son>
</template>

<script setup lang="ts">
import Son from './components/Son.vue'
const sonSend = (val:number[]) => {
    console.log('子组件传过来的值',val)
}

</script>

7 父组件使用子组件的方法或属性,要在子组件中通过defineExpose向外暴露出去

//  子组件
<script lang="ts" setup>
import { ref} from "vue";
const list = ref<number[]>([7,8,9])
const test = () => {
    console.log('子组件的方法')
}
// defineExpose用法,可以向外暴露属性或者方法
defineExpose({
    list,  // list是向外暴露的属性/值
    test,  // test是向外暴露的方法
})
</script>

8 父组件中使用子组件的方法,要通过ref获取子组件实例

//  父组件
<template>
  <Son ref="sonRef"></Son>
</template>


<script setup lang="ts">
import Son from './components/Son.vue'
import {onMounted, ref} from "vue";

const sonRef = ref()

//使用子子组件的属性
onMounted(()=>{
    console.log(sonRef.value?.list)  // 这里为了测试,可以不在mounted中,根据自己在哪个地方使用即可
    console.log(sonRef.value?.test())
})
</script>

### Vue3子组件父组件传参并在父组件中使用参数查询的方法Vue3中,子组件可以通过`emit`方法将数据传递给父组件父组件通过监听子组件触发的自定义事件来接收这些数据,并将其用于后续操作,例如执行查询等逻辑[^3]。 以下是实现该功能的具体方式: #### 子组件部分 子组件通过`defineEmits`定义一个多个事件,然后在需要时调用`emit`方法触发事件并传递参数。 ```vue <template> <button @click="sendDataToParent">发送数据到父组件</button> </template> <script lang="ts"> import { defineComponent } from &#39;vue&#39;; export default defineComponent({ name: &#39;ChildComponent&#39;, emits: [&#39;passFatheditScreen&#39;], // 定义事件名 methods: { sendDataToParent() { const dataToSend = { key: &#39;value&#39;, anotherKey: 123 }; // 准备要传递的数据 this.$emit(&#39;passFatheditScreen&#39;, dataToSend); // 触发事件并传递数据 } } }); </script> ``` #### 父组件部分 父组件通过`v-on`简写`@`监听子组件触发的事件,并定义相应的处理函数来接收处理传递过来的数据。 ```vue <template> <div> <child-component @passFatheditScreen="handleSonValue" /> <button @click="performQuery">执行查询</button> </div> </template> <script lang="ts"> import { defineComponent, ref } from &#39;vue&#39;; import ChildComponent from &#39;./ChildComponent.vue&#39;; export default defineComponent({ name: &#39;ParentComponent&#39;, components: { ChildComponent }, setup() { const receivedData = ref<{ key: string; anotherKey: number } | null>(null); const handleSonValue = (data: { key: string; anotherKey: number }) => { receivedData.value = data; // 接收子组件传递的数据 }; const performQuery = () => { if (receivedData.value) { console.log(&#39;执行查询,使用子组件传递的数据:&#39;, receivedData.value); // 在这里可以调用API其他查询逻辑 } else { console.warn(&#39;未接收到子组件的数据&#39;); } }; return { handleSonValue, performQuery }; } }); </script> ``` 上述代码展示了如何在Vue3中实现子组件父组件传递参数,并在父组件中使用这些参数进行查询的完整流程[^3]。 --- ### 注意事项 - **类型安全**:如果使用TypeScript,建议为传递的数据定义明确的类型,以确保类型安全。 - **事件命名规范**:推荐使用语义化且清晰的事件名称,便于维护理解。 - **响应式数据**:父组件中接收的数据应尽量使用`ref``reactive`包裹,以确保其具备响应式特性。 --- #### 示例总结 通过子组件的`emit`方法父组件的事件监听机制,可以轻松实现父子组件之间的参数传递,并在父组件中利用这些参数完成进一步的操作,如查询、更新状态等。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值