[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法

作者 : admin 本文共1580个字,预计阅读时间需要4分钟 发布时间: 2024-06-11 共3人阅读

经典面试题:请阐述一下 v-model 的原理

经典面试题:请说一下vue2与vue3在使用 v-model 时的异同点

经典面试题:请列举 vue2/vue3 的父子组件的数据双向绑定的多种写法

 本文即可将上述三个面试题阐述清楚,并提供具体案例来让小伙伴们加深理解、彻底掌握!本文较长,小伙伴们可以先收藏+关注,抽空学习哦~💕

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图

💟 上一篇文章 vue3父子组件相互调用方法详解(热榜前十)

📝 系列专栏 vue从基础到起飞

 [vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(1)

v-model 可以作用于表单元素,又可作用于自定义组件,无论是哪一种情况(vue2, vue3),它都是一个语法糖,最终会生成一个属性和一个事件

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(2)

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(3)

当其作用于表单元素时vue会根据作用的表单元素类型而生成合适的属性和事件。例如:

  • text 和 textarea 元素使用 value property 和 input 事件;
  • checkbox 和 radio 使用 checked property 和 change 事件;
  • select 字段将 value 作为 prop 并将 change 作为事件。

v-model用于自定义组件

vue2的情况

v-model也可作用于自定义组件,当其作用于自定义组件时,默认情况下,它会生成一个value属性和input事件。

子组件 HelloWorld.vue

这个子组件只是实现一个简单计数器的功能,然后我向上分发的事件名称是update:value。但是vue2如果使用v-model会自动的把这个事件名称给改成input


  
    
    {{value}}
    
  



复制代码
APP.vue 来使用

等效于

复制代码

结果:
[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(4)

分析虚拟dom结果

vue2的虚拟dom查看方式是 在mounted中使用this._vnode来进行查看,然后查看componentOptions来查看组件传递的属性。

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(5)

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(6)

开发者可以通过组件的model配置来改变生成的属性和事件,例如:
 修改子组件 HelloWorld.vue

  
    
    {{ number }}
    
  



复制代码

父组件修改



复制代码
效果

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(7)

vue3的情况

v-model也可作用于自定义组件,当其作用于自定义组件时,默认情况下,它会生成一个modelValue属性和onUpdate:modelValue事件。

子组件 Comp.vue

                             
  
  {{props.modelValue}}
  

复制代码
父组件App.vue

等效于

复制代码
结果
[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(8)

虚拟dom分析

vue3 的查看虚拟dom的使用方式,是使用“getCurrentInstance`来查看, 里面的children中的props中来查看属性传递

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(9)

区别

vue2和vue3都有v-model,原理都是生成一个属性和一个事件,但是也存在些区别 , 区别如下:

.sync修饰符

vue3中的.sync修饰符是去掉了的,他的功能可以由v-model的参数替代

例如:




复制代码
多个v-model

vue3中允许你写多个v-model,这也是强烈的说明了,v-model就是一个语法糖,只是帮你减少了代码量,仅此而已。vue2不能写多个v-model




复制代码
##v-model 的修饰符不同

vue2.x是自带的修饰符,但是在3.x的版本中,可以自定义修饰符哦 .在3.x中的修饰符会在当作属性传递给子组件,并且在属性中生成一个modelModifiers的属性。存在这个修饰符就会有对应的修饰符,并且是true,如果没有传递,那就是undefined。

示例代码:

修改子组件Comp.vue


                             
  
  {{props.modelValue}}
  

复制代码

父组件使用

复制代码

效果

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(10)

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(11)

🚀 个人简介:6年开发经验,现任职某国企前端负责人,分享前端相关技术与工作常见问题~
💟 作    者:前端菜鸟的自我修养❣️
📝 专    栏:vue从基础到起飞
🌈 若有帮助,还请关注➕点赞➕收藏,不行的话我再努努力💪💪💪

更多专栏订阅推荐:

👍 前端工程搭建
💕 JavaScript深入研究

📝 前端工作常见问题汇总

[vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法插图(12)

本站无任何商业行为
个人在线分享 » [vue2/vue3] — 深入剖析v-model的原理、父子组件双向绑定的多种写法
E-->