news 2026/5/4 10:16:45

Vue 3 踩坑录:`.sync` 在 `setup()` 里失效?—— 一次搞懂 v-model 升级与替代方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue 3 踩坑录:`.sync` 在 `setup()` 里失效?—— 一次搞懂 v-model 升级与替代方案

Vue 3 踩坑录:.syncsetup()里失效?—— 一次搞懂 v-model 升级与替代方案

一、问题现象

当你在 Vue 3 的<script setup>中写下:

<MyComp :title.sync="pageTitle" />

控制台立刻弹出警告:

The.syncmodifier is not supported in setup() function.

翻译:Vue 3 的setup语法糖里不再提供.sync,请使用新的v-model语法。


二、为什么.sync被移除?

  1. 语法冗余.sync本质是v-bind+ 自定义事件,易与v-model混淆。
  2. 统一模型:Vue 3 将所有双向绑定归并为v-model,支持多个、自定义名称,更直观。
  3. setup 简化<script setup>编译时直接生成v-model调用,.sync不再被编译。

三、升级路线图(对照表)

Vue 2 写法Vue 3 等价(setup)
:title.sync="val"v-model:title="val"
@update:title="val = $event"自动由v-model触发
多个.sync多个v-model

四、代码改造示例

1. 子组件:用defineEmits抛出事件

<!-- MyComp.vue --> <script setup> const props = defineProps({ title: String }) const emit = defineEmits(['update:title']) function onInput(e) { emit('update:title', e.target.value) } </script> <template> <input :value="title" @input="onInput" /> </template>

2. 父组件:新语法v-model:title

<script setup> import { ref } from 'vue' const pageTitle = ref('Vue 3') </script> <template> <!-- ✅ 新语法 --> <MyComp v-model:title="pageTitle" /> <p>{{ pageTitle }}</p> </template>

五、多个双向绑定(多v-model

<!-- 子组件 --> defineEmits(['update:title', 'update:count']) <!-- 父组件 --> <MyComp v-model:title="pageTitle" v-model:count="pageCount" />

六、兼容性方案(临时)

若必须保持.sync(老库迁移):

  1. 使用选项式 API(无<script setup>);
  2. 或通过custom directive手动实现.sync行为(不推荐)。

七、一键检查清单

  • 全部:xxx.sync改为v-model:xxx
  • 子组件抛出update:xxx事件
  • 多个双向绑定用多v-model
  • ESLint 规则vue/no-deprecated-sync-modifier开启

八、一句话总结

.sync已成历史,v-model才是未来。
:xxx.sync改成v-model:xxx,一次性拥抱 Vue 3 统一、简洁的双向绑定模型!


最后问候亲爱的朋友们,并邀请你们阅读我的全新著作

📚 《Vue.js 3企业级项目开发实战(微课视频版》

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 23:55:25

COMSOL氨气催化裂解:不同压力、温度下的性能分析

COMSOL氨气催化裂解。 不同压力&#xff0c;不同温度下的NH3催化裂解。氨气&#xff08;NH₃&#xff09;催化裂解是一种常见的化学催化技术&#xff0c;广泛应用于石油 refining 和合成化学中。通过在催化剂的作用下&#xff0c;将长链烃类物质裂解为短链产物&#xff0c;同时…

作者头像 李华
网站建设 2026/5/1 0:15:09

Git监控工具终极指南:lazygit操作行为分析完全手册

Git监控工具终极指南&#xff1a;lazygit操作行为分析完全手册 【免费下载链接】lazygit 一个简化的终端用户界面&#xff0c;用于执行Git命令&#xff0c;旨在提高开发者使用Git的效率和体验。 项目地址: https://gitcode.com/GitHub_Trending/la/lazygit 在当今快速发…

作者头像 李华
网站建设 2026/5/1 0:15:02

Java 8都出了这么多年,Optional还是没人用?到底卡在哪了?

Java 8 都快 12 岁了&#xff0c;Optional<T> 确实还是“半红不紫”&#xff0c;真实项目里你打开一个 2025 年的 Spring Boot 代码库&#xff0c;十有八九还是满屏 if (obj ! null)&#xff0c;真正用好 Optional 的团队屈指可数。到底卡在哪&#xff1f;下面把真实原因…

作者头像 李华
网站建设 2026/5/2 22:29:51

Windows快捷键修复大师:一键诊断系统热键冲突的智能工具

Windows快捷键修复大师&#xff1a;一键诊断系统热键冲突的智能工具 【免费下载链接】hotkey-detective A small program for investigating stolen hotkeys under Windows 8 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 在Windows操作系统中&#x…

作者头像 李华
网站建设 2026/5/4 6:05:14

我的AI自学路线,可能对你有用

以下是 2025&#xff5e;2026 年真正能让你「从 0 到年薪 60w&#xff0b;/独立接单 10w&#xff0b;/发顶会顶刊」的超详细 AI 自学路线&#xff0c;按阶段划分得巨细。我把它拆成了 8 个阶段&#xff0c;每个阶段都写清楚&#xff1a; 目标、核心课程、书籍、项目、耗时、验收…

作者头像 李华
网站建设 2026/5/4 5:18:36

实时协作编辑器:开源技术重新定义团队文档协作体验

实时协作编辑器&#xff1a;开源技术重新定义团队文档协作体验 【免费下载链接】hedgedoc 项目地址: https://gitcode.com/gh_mirrors/server4/server 在当今数字化工作环境中&#xff0c;协作编辑器已成为团队效率的核心工具。基于Yjs技术的开源实时编辑解决方案&…

作者头像 李华