在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中,推荐使用这种方式来实现父子组件间的数据同步。