在 Vue 3 组合式 API 中,通过 provide 传递 ref 对象后,子组件 inject 得到的是该响应式引用本身(即 Ref<T>),而非其 .value;模板中应直接访问 selectedReceipt.id,而非 selectedReceipt?.value?.id,否则首次渲染时因响应式依赖未触发而报 undefined。
在 vue 3 组合式 api 中,通过 `provide` 传递 `ref` 对象后,子组件 `inject` 得到的是该响应式引用本身(即 `ref`),而非其 `.value`;模板中应直接访问 `selectedreceipt.id`,而非 `selectedreceipt?.value?.id`,否则首次渲染时因响应式依赖未触发而报 `undefined`。
当使用 provide/inject 在父子组件间共享响应式状态时,一个常见误区是混淆了“引用对象”与“引用值”的访问方式。你已在父组件中正确声明并提供了一个 ref:
const selectedReceipt = ref([]);provide('selectedReceipt', selectedReceipt); // ✅ 提供的是 ref 实例
这意味着子组件注入得到的 selectedReceipt 本身就是一个 Ref<any[]> 类型的对象(即包含 .value 属性的响应式包装器),而非解包后的原始值。
因此,在子组件模板中,应直接使用 selectedReceipt.id(等价于 selectedReceipt.value?.id),因为 Vue 模板语法会自动对 Ref 进行 .value 解包(仅限模板中):
<a :href="'printDetails/' + selectedReceipt?.id">Print</a><!-- ✅ 正确:Vue 模板自动读取 .value -->
而以下写法是错误的:
立即学习“前端免费学习笔记(深入)”;
<a :href="'printDetails/' + selectedReceipt?.value?.id">Print</a><!-- ❌ 错误:手动访问 .value 在模板中冗余且易引发 undefined 错误 -->
⚠️ 注意事项:
watch(() => selectedReceipt.value, (newVal) => { if (newVal && newVal.length > 0) { const receipt = newVal[0]; // 假设为单条数据 master_Filter.value.hospital_id = receipt.hospitals?.en_name; master_Filter.value.assessment_date = receipt.assessment_date; master_Filter.value.maktoob_no = receipt.maktoob_no; master_Filter.value.maktoob_date = receipt.maktoob_date; getDetails(); }}, { immediate: true, deep: true });
✅ 最佳实践总结:
这样即可彻底解决 selectedReceipt 在模板中为 undefined、链接跳转失败的问题,并确保响应式更新及时可靠。