Vue2/3 v-model 使用区别详解,不了解的来看看

使用Vue的开发人员肯定对Vue2中的v-model非常熟悉,大家平常写起来也非常顺手,但是v-model在vue3中发生了较大的变化。这里简单阐述一下Vue3中v-model新语法的使用以及为什么有新的语法。

Vue2.x中v-model的使用以及问题

v-model在vue2.x中的使用方式

我们首先看一下vue2.x中v-model的使用。

ini 复制代码
<ChildComponent v-model = "title />

它实际上是下面这种写法的简写:

ini 复制代码
<ChildComponent :value = "title"  @input = "title = $event" />

也就是说,它实际上是传递一个属性value,然后接收一个input事件。

vue2.x中v-model的问题

虽然v-model在vue2.x中使用起来很方便,也很简单,但是它存在一个问题:那就是传递下去的必须是value值,接收的也必须是input事件 。事实上,并不是所有的元素都适合传递value,比如<input type="checkbox">,当type属性的值为checkbox是,实际上是checked这个属性的存在用来表示是否被选中,而value值是另外的含义。而且有些时候,一些组件并不是通过input来进行触发事件。也就是说valueinput事件在大多数情况下能够适用,但是存在value另有含义,或者不能使用input触发的情况,这时候我们就不能使用v-model进行简写了。为了解决这个问题,尤雨溪在Vue2.2中,引入了model组件选项,也即是说你可以通过model来指定v-model绑定的值和属性.如下所示:

ini 复制代码
<ChildComponent v-model="title" />

在子组件中这样设置:

arduino 复制代码
export default {
  model: {
    prop: 'title',   // v-model绑定的属性名称
    event: 'change'  // v-model绑定的事件
  },
  props: {

    value: String,   // value跟v-model无关
    title: {         // title是跟v-model绑定的属性
      type: String,
      default: 'Default title'
    }
  }
}

通过上面的代码,我们可以看到通过设置model选项,我们就可以直接使用指定的属性和事件,而不需要必须使用valueinput了,valueinput可以另外它用了。

Vu3中v-model的使用

Vue3中v-model的基础使用

我们通过上面知道vue2.x中既然v-model的主要原因是由于valueinput事件可能另有它用,那么我们可不可以直接使用另外的属性和方法,而不需要去通过model进行定义。vue3中就实现了这个功能,v-model绑定的不再是value,而是modelValue,接收的方法也不再是input,而是update:modelValue。使用方法如下:

ini 复制代码
<ChildComponent v-model = "title">

它是下面这种写法的简写:

ruby 复制代码
<ChildComponent :modelValue = "title" @update:modelValue = "title = $event">

在子组件中写法是:

javascript 复制代码
export default defineComponent({
    name:"ValidateInput",
    props:{
        modelValue:String,   // v-model绑定的属性值
    },
    setup(){
        const updateValue = (e: KeyboardEvent) => {
          context.emit("update:modelValue",targetValue);   // 传递的方法
        }
    }
}

也就是说vue3中,value改成了modelValueinput方法了改成update:modelValue

更换v-model的参数

vue3中使用了modelValue来替代value,但是modelValue不太具备可读性,在子组件的props中看到这个都不知道是什么。 因此,我们希望能够更加见名知意。可以通过:xxx传递参数xxx,更改名称,而不是像vue2中使用model选项。使用方式如下:

ini 复制代码
<ChildComponent v-model:title="title" />

那么在子组件中,就可以使用title代替modelValue

javascript 复制代码
export default defineComponent({
    name:"ValidateInput",
    props:{
        // modelValue:String,
        title:String,   // title替代了modelValue
    },
    setup(){
        const updateValue = (e: KeyboardEvent) => {
        //   context.emit("update:modelValue",targetValue);   // 传递的方法
          context.emit("update:title",targetValue);   // 传递的方法
        }
    }
}

也就是说,我们最终的使用方法是:

ini 复制代码
<ChildComponent v-model:title="title"  />
// 或者
<ChildComponent :title="title" @update:title = "title = $event" />

好了,到目前为止,我们介绍了vue2中的v-model的使用以及问题,vue3中v-model的新的使用语法。赶快去体验vue3的使用吧。

相关推荐
知识分享小能手1 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
魔云连洲1 小时前
深入解析:Vue与React的异步批处理更新机制
前端·vue.js·react.js
mCell1 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
weixin_437830943 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
超级无敌攻城狮3 小时前
3 分钟学会!波浪文字动画超详细教程,从 0 到 1 实现「思考中 / 加载中」高级效果
前端
excel4 小时前
用 TensorFlow.js Node 实现猫图像识别(教学版逐步分解)
前端
前端工作日常4 小时前
我学习到的Vue2.6的prop修饰符
vue.js
gnip4 小时前
JavaScript事件流
前端·javascript
小菜全4 小时前
基于若依框架Vue+TS导出PDF文件的方法
javascript·vue.js·前端框架·json