nuxt3如何进行组件传值同步数据呢?
在Nuxt 3中,组件间传值和同步数据可以通过组合式API中的provide
和inject
来实现。以下是一个简单的例子:
父组件 (Parent.vue
):
<template>
<Child :value="message" @update:value="updateMessage" />
</template>
<script setup>
import { ref } from 'vue'
import Child from './Child.vue'
const message = ref('Hello, World!')
function updateMessage(newValue) {
message.value = newValue
}
</script>
子组件 (Child.vue
):
<template>
<input :value="value" @input="$emit('update:value', $event.target.value)" />
</template>
<script setup>
import { defineProps, defineEmits } from 'vue'
const props = defineProps({
value: String
})
const emit = defineEmits(['update:value'])
</script>
在这个例子中,父组件通过v-model
指令绑定message
到子组件的value
属性,并监听update:value
事件来更新message
。子组件通过$emit
方法发送update:value
事件,并将输入框的当前值作为参数传递。
这种方式类似于Vue 2.x中的.sync
修饰符,但是更加显式和可控。在Nuxt 3中,推荐使用这种方式来实现父子组件间的数据同步。
评论已关闭