news 2026/6/10 19:11:47

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/6/10 5:35:53

music-api:快速上手的跨平台音乐解析完整教程

还在为不同音乐平台的API接入而烦恼吗&#xff1f;music-api项目为你提供了一站式解决方案&#xff0c;让你轻松获取四大主流音乐平台的歌曲播放地址。无论是开发音乐播放器、构建推荐系统&#xff0c;还是创建个人音乐网站&#xff0c;这个开源工具都能显著提升你的开发效率。…

作者头像 李华
网站建设 2026/6/10 12:25:14

科技赋能文化养老,红松小课开启退休生活品质新时代

在数字中国建设全面推进的今天&#xff0c;科技应用正在为各个年龄群体创造更加便捷、丰富的生活方式。对于规模日益庞大的退休群体而言&#xff0c;科技不仅是工具&#xff0c;更是连接社会、实现自我价值的重要桥梁。专注于服务退休人群的红松小课&#xff0c;正是通过技术创…

作者头像 李华
网站建设 2026/6/10 10:06:33

在asp.net web应用程序,老是访问同一个Handler1.ashx

前言项目是在vs2022下开发&#xff0c;在一般处理程序有二个文件moveToUp.ashx和moveToTop.ashx。在模拟和项目中请求访问时老是指向moveToTop.ashx。上下项目全部度找问题&#xff0c;清仓项目&#xff0c;重新生成&#xff0c;删除bin和obj目录下所有文件&#xff0c;还是这指…

作者头像 李华
网站建设 2026/6/10 17:35:31

机械故障诊断完整指南:基于振动信号分析的实战教程

机械故障诊断完整指南&#xff1a;基于振动信号分析的实战教程 【免费下载链接】机械故障诊断与振动信号数据集 本仓库提供了一个振动信号数据集&#xff0c;旨在帮助工程师和科学家对机械设备的振动信号进行分析和处理。该数据集包含了多个振动信号示例&#xff0c;适用于故障…

作者头像 李华
网站建设 2026/6/9 16:24:18

TIOBE 编程社区 查看各种编程语言流行程度和趋势的社区

TIOBE 编程社区&#xff1a;查看编程语言流行程度和趋势的权威平台 TIOBE 编程社区指数&#xff08;TIOBE Programming Community Index&#xff09;是一个全球知名的编程语言流行度指标&#xff0c;由荷兰软件公司 TIOBE 维护。它通过分析搜索引擎&#xff08;如 Google、Bin…

作者头像 李华
网站建设 2026/6/10 13:06:59

基于Vue框架的宠物医院系统设计与实现

青岛恒星科技学院 毕业论文&#xff08;设计&#xff09;开题报告 题 目&#xff1a; 基于Vue框架的宠物医院系统 设计与实现 学 院 信息工程学院 专 业 软件工程 校 号 2102772 学 生 高爱鹏…

作者头像 李华