news 2026/3/31 11:33:38

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/3/31 9:47:17

模拟IC电路设计从入门到上手:视频教程全攻略

模拟ic电路设计&#xff0c;版图设计&#xff0c;仿真视频教程 运算放大器&#xff0c;带隙基准&#xff0c;LDO&#xff0c;ADC模数转换器&#xff0c;射频ic设计&#xff0c;模拟版图设计 讲的很好&#xff0c;学完后可快速上手在模拟IC设计这个充满挑战与魅力的领域&#xf…

作者头像 李华
网站建设 2026/3/23 6:36:32

大连艾森诺手动打销机,销轴拆卸高效神器

大连艾森诺手动打销机&#xff0c;销轴拆卸高效神器在铸造、机械装配与维修场景中&#xff0c;销轴、销子的拆卸向来是棘手难题。传统依赖铁锤敲击、凿子撬动的方式&#xff0c;不仅耗时费力、工人劳动强度大&#xff0c;还易损伤工件本体&#xff0c;导致设备精度下降甚至报废…

作者头像 李华
网站建设 2026/3/31 17:22:42

BlenderMCP终极指南:5步快速将3D模型转换为像素艺术资产

BlenderMCP终极指南&#xff1a;5步快速将3D模型转换为像素艺术资产 【免费下载链接】blender-mcp 项目地址: https://gitcode.com/GitHub_Trending/bl/blender-mcp 还在为3D模型转换为像素风格而头疼吗&#xff1f;传统方法需要复杂的材质设置、繁琐的UV调整和大量的手…

作者头像 李华
网站建设 2026/3/13 0:13:49

Solidity 抽象合约与接口合约详解

一、抽象合约 (Abstract Contract) 1.1 定义与特点 // 使用 abstract 关键字声明 abstract contract AbstractExample {// 抽象函数&#xff1a;只有声明&#xff0c;没有实现体&#xff0c;以分号结尾function abstractFunction() public virtual returns(uint256);// 可以有已…

作者头像 李华
网站建设 2026/3/31 19:33:12

阴阳师御魂自动刷取神器:解放双手的智能辅助方案

阴阳师御魂自动刷取神器&#xff1a;解放双手的智能辅助方案 【免费下载链接】yysScript 阴阳师脚本 支持御魂副本 双开 项目地址: https://gitcode.com/gh_mirrors/yy/yysScript 面对阴阳师游戏中每日重复的御魂副本挑战&#xff0c;你是否也感到疲惫不堪&#xff1f;y…

作者头像 李华
网站建设 2026/3/27 2:11:45

发那科机器人CRM52A/CRM52B接口技术详解

发那科机器人CRM52A/CRM52B接口技术详解 【免费下载链接】发那科机器人CRM52ACRM52B接口说明 发那科机器人CRM52A、CRM52B接口说明 项目地址: https://gitcode.com/Open-source-documentation-tutorial/71d54 接口概述与重要性 发那科机器人的CRM52A和CRM52B接口是工业…

作者头像 李华