很多同学对 Vue 的第一印象就是“响应式”、“双向绑定”等特性,而 v-model 就是实现双向绑定的语法糖,用过 Vue 的小伙伴一定都非常熟悉。但是在 Vue3 中,v-model 发生了一些改动,使得它不再兼容 Vue2 的用法,具体是什么呢,我们一起来看看。

非兼容:用于自定义组件时,v-model prop 和事件默认名称已更改:

  • prop:value -> modelValue
  • 事件:input -> update:modelValue

非兼容v-bind.sync 修饰符和组件的 model 选项已移除,可在 v-model 上加一个参数代替;

新增:现在可以在同一个组件上使用多个 v-model 绑定;
新增:现在可以自定义 v-model 修饰符。

2.x 语法

在 2.x 中,在组件上使用 v-model 相当于绑定 value prop 并触发 input 事件:

<ChildComponent v-model="pageTitle" /><!-- 是以下的简写: --><ChildComponent :value="pageTitle" @input="pageTitle = $event" />

这里 v-model 实际上就是为表单元素定制的,input 事件和 value prop 都是强耦合的

如果想要更改 prop 或事件名称,则需要在 ChildComponent 组件中添加 model 选项:

<!-- ParentComponent.vue --><ChildComponent v-model="pageTitle" />
// ChildComponent.vueexport default {model: {prop: 'title',event: 'change'},props: {// 这将允许 `value` 属性用于其他用途value: String,// 使用 `title` 代替 `value` 作为 model 的 proptitle: {type: String,default: 'Default title'}}
}

所以,在这个例子中 v-model 是以下的简写:

<ChildComponent :title="pageTitle" @change="pageTitle = $event" />

某些情况下,我们可能需要对某个 prop 进行“双向绑定”,例如一个弹框组件的显示隐藏,既可以从组件外面进行控制,也可以从组件内部去控制。为此,我们建议使用 update:myPropName 抛出事件。例如,对于在上一个示例中带有 title prop 的 ChildComponent,我们可以通过下面的方式将分配新 value 的意图传达给父级:

this.$emit('update:title', newValue)

然后父组件可以在需要时监听该事件,并更新本地的 data property。例如:

<ChildComponent :title="pageTitle" @update:title="pageTitle = $event" />

为了方便起见,我们可以使用 .sync 修饰符来缩写,如下所示:

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

.sync 实际上就是上面的语法糖,可以看到其实和 v-model 用法非常相似

3.x 语法

在 3.x 中,自定义组件上的 v-model 相当于传递了 modelValue prop 并接收抛出的 update:modelValue 事件:

<ChildComponent v-model="pageTitle" /><!-- 是以下的简写: --><ChildComponent:modelValue="pageTitle"@update:modelValue="pageTitle = $event"
/>

若需要更改 model 的名称,现在我们可以为 v-model 传递一个参数,以作为组件内 model 选项的替代:

<ChildComponent v-model:title="pageTitle" /><!-- 是以下的简写: --><ChildComponent :title="pageTitle" @update:title="pageTitle = $event" />


这也可以作为 .sync 修饰符的替代,而且允许我们在自定义组件上使用多个 v-model

<ChildComponent v-model:title="pageTitle" v-model:content="pageContent" /><!-- 是以下的简写: --><ChildComponent:title="pageTitle"@update:title="pageTitle = $event":content="pageContent"@update:content="pageContent = $event"
/>

题外话

在 React 中如何实现类似功能?通过将修改状态的代码包裹在函数中,作为 prop 传递给子组件,子组件调用之后,闭包的引用发生变化,导致父组件状态被修改,进而改变传入子组件的 prop 的值:

const Parent = () => {const [count, setCount] = React.useState(0);const plusOne = () => setCount(count + 1);return (<Child count={count} onClick={plusOne} />)
}const Child = ({ count, onClick }) => {return (<><span>{count}</span><button onClick={onClick}>点我</button></>)
}

参考

Vue3 官方文档 - v-model

浅谈 Vue3 中的 v-model 和 sync 修饰符相关推荐

  1. 浅谈Android中的MVP与动态代理的结合

    浅谈Android中的MVP与动态代理的结合 本篇文章已授权微信公众号 guolin_blog (郭霖)独家发布 在Android开发平台上接触MVP足足算起来大概已经有一个年头左右.从最开始到现在经 ...

  2. python文件路径拼接多出斜杠_浅谈python中拼接路径os.path.join斜杠的问题

    浅谈python中拼接路径os.path.join斜杠的问题 调试程序的过程中,发现通过os.path.join拼接的路径出现了反斜杠 directory1='/opt/apps/upgradePac ...

  3. 【网摘】 浅谈HTTP中GET与POST的区别

    文章出处:http://www.cnblogs.com/hyddd/archive/2009/03/31/1426026.html 浅谈HTTP中Get与Post的区别 Http定义了与服务器交互的不 ...

  4. swift 引用其他类_浅谈swift中闭包修饰符 weak?unowned? 或什么都不用

    浅谈swift中闭包修饰符 weak?unowned? 或什么都不用 平常的开发中,clourse是我们iOSr绕不过去的坎儿. 苹果本身也很重视闭包,像之前的一些老的target-action类型的 ...

  5. 浅谈Java中的栈和堆

    人们常说堆栈堆栈,堆和栈是内存中两处不一样的地方,什么样的数据存在栈,又是什么样的数据存在堆中? 这里浅谈Java中的栈和堆 首先,将结论写在前面,后面再用例子加以验证. Java的栈中存储以下类型数 ...

  6. 浅谈C#中的延“.NET研究”迟加载(2)——善用virtual

    之前的文章"浅谈C#中的延迟加载(1)--善用委托"中介绍了三层结构中在Model层对实体类的属性实现延迟加载的方法,该方法利用C#中的委托来实现,最后虽然延迟加载的目的得以实现, ...

  7. 浅谈yolov4中的一部分数据增强

    浅谈yolov4中的数据增强 前言 数据增强 数据增强步骤 1.对图片进行水平翻转 2.对图片进行缩放 3.对图片HSV色域变换 4. Mosaic数据增强 5. 总代码 前言 在接下来的几天,我将解 ...

  8. aba会导致问题_浅谈Java中ABA问题及避免

    本文主要研究的是关于Java中ABA问题及避免的相关内容,具体如下. 在<Java并发实战>一书的第15章中有一个用原子变量实现的并发栈,代码如下: public class Node { ...

  9. java 线程aba,浅谈Java中ABA问题及避免,浅谈javaaba避免

    浅谈Java中ABA问题及避免,浅谈javaaba避免 本文主要研究的是关于Java中ABA问题及避免的相关内容,具体如下. 在<Java并发实战>一书的第15章中有一个用原子变量实现的并 ...

最新文章

  1. ConnectionAbortedError: [WinError 10053] 您的主机中的软件中止了一个已建立的连接
  2. java mobile phone games_j2me100-src Java
  3. 杨桃32开发版最小核心板和底板接口定义以及各io口功能
  4. 关于三岔路口双车接力,这位同学把问题总算问清楚了
  5. LeetCode-数组-删除有序数组重复元素
  6. Windbg+sos调试.net笔记
  7. 杭电1043java实现bfs一遍
  8. c语言程序参数mook,C语言程序设计-中国大学mooc-题库零氪
  9. ASP.NET MVC 入门6、TempData
  10. 用Python把github上非常实用的数据全部抓取下来! 留给自己备用
  11. 今天最好的生日礼物就是重新找到目标
  12. java spin lock_JAVA 各种锁机制
  13. Jmeter-【JSON Extractor】-响应结果中数组多个相同key取值
  14. mysql数据库学习6_MySQL学习(六)
  15. iOS 自定义视频播放器
  16. 想开发一个在线的合同模板管理套件
  17. (2021) 26 [持久化] 持久数据的可靠性:RAID和journaling
  18. 微信电脑版qq文件服务器,不用QQ微信,简单几步让电脑手机快速互传共享文件...
  19. Ae 表达式语言引用​:Comp
  20. U盘文件、文件夹不显示却能搜索到 显示U盘文件的解决办法

热门文章

  1. 磺酸基-Cy5 羧酸Sulfo-Cy5 COOH分子式C32H37N2KO8S2
  2. ​LeetCode刷题实战631:设计 Excel 求和公式
  3. echart 地图 各省市数据
  4. 发福利,整理了一份关于“资源汇总”的汇总
  5. 大工《计算机应用基础》试题,大工18春《计算机应用基础》在线测试123试题答案...
  6. excel一键把文章链接转换成超链接【hyperlink函数】
  7. 要闻君说:金拱门要进攻科技圈了?5G探索仍在继续,6G发现就已“上马”;Kubernetes 1.14版本正式来袭...
  8. 网易 天下2 的简单评论
  9. 菜鸟裹裹App分析系列-产品分析
  10. linux驱动篇-touchscreen-完整版