美文网首页
Vue3-表单绑定

Vue3-表单绑定

作者: Imkata | 来源:发表于2022-04-26 14:11 被阅读0次

v-model的基本使用

表单提交是开发中非常常见的功能,也是和用户交互的重要手段,比如用户在登录、注册时需要提交账号密码,比如用户在检索、创建、更新信息时,需要提交一些数据。

这些都要求我们可以在代码逻辑中获取到用户提交的数据,我们通常会使用v-model指令来完成。v-model指令可以在input、textarea、checkbox、radio、select上创建双向数据绑定,它会根据控件类型自动选取正确的方法来更新元素,尽管有些神奇,但 v-model 本质上不过是语法糖,它负责监听用户的输入事件来更新数据,并在某种极端场景下进行一些特殊处理。

image.png

v-model的原理

官方有说到,v-model的原理其实是背后有两个操作:

  • v-bind绑定value属性的值
  • v-on绑定input事件监听到函数中,函数会获取最新的值赋值到绑定的属性中

事实上v-model更加复杂

v-model绑定textarea

除了绑定到input,还可以绑定其他的表单类型:textarea、checkbox、radio、select。

我们先来看一下绑定textarea:

<!-- 1.绑定textarea -->
<label for="intro">
  自我介绍
  <textarea name="intro" id="intro" cols="30" rows="10" v-model="intro"></textarea>
</label>
<h2>intro: {{intro}}</h2>

v-model绑定checkbox

v-model绑定checkbox,分为单个勾选框和多个勾选框。

  • 绑定单个勾选框,v-model即为布尔值。此时input的value并不影响v-model的值。
  • 绑定多个复选框,当是多个复选框时,因为可以选中多个,所以对应的data中属性是一个数组。当选中某一个时,就会将input的value添加到数组中。
<!-- 2.1.单选框 -->
<label for="agree">
  <input id="agree" type="checkbox" v-model="isAgree"> 同意协议
</label>
<h2>isAgree: {{isAgree}}</h2>

<!-- 2.2.多选框 -->
<span>你的爱好: </span>
<label for="basketball">
  <input id="basketball" type="checkbox" v-model="hobbies" value="basketball"> 篮球
</label>
<label for="football">
  <input id="football" type="checkbox" v-model="hobbies" value="football"> 足球
</label>
<label for="tennis">
  <input id="tennis" type="checkbox" v-model="hobbies" value="tennis"> 网球
</label>
<h2>hobbies: {{hobbies}}</h2>

data() {
  return {
    isAgree: false,
    hobbies: ["basketball"]
  }
},

v-model绑定radio

v-model绑定radio的同一个值上,用于选择其中一项。一般用于男女等。

<label for="male">
  <input id="male" type="radio" v-model="gender" value="male">男
</label>
<label for="female">
  <input id="female" type="radio" v-model="gender" value="female">女
</label>
<h2>gender: {{gender}}</h2>

data() {
  return {
    gender: ""
  }
},

v-model绑定select

和checkbox一样,select也分单选和多选两种情况。

  • 单选:只能选中一个值,v-model绑定的是一个值。当我们选中option中的一个时,会将它对应的value赋值到fruit中。
  • 多选:可以选中多个值,v-model绑定的是一个数组,当多选后,这时候fruit就变成了数组,里面放的是选中的水果。
<!-- v-model绑定的值就是默认的值,如果没指定,那么默认值就是第一个 -->
<!-- multiple size="2" 代表允许多选,并且最多选两个 -->
<select v-model="fruit" multiple size="2">
  <option value="apple">苹果</option>
  <option value="orange">橘子</option>
  <option value="banana">香蕉</option>
</select>
<h2>fruit: {{fruit}}</h2>

data() {
  return {
    fruit: "orange"
  }
},

v-model的值绑定

目前我们在前面的案例中大部分的值都是在template中固定好的,比如gender的两个输入框值male、female,比如hobbies的三个输入框值basketball、football、tennis。在真实开发中,我们的数据可能是来自服务器的,那么我们就可以先将值请求下来,绑定到data返回的对象中,再通过v-bind来进行值的绑定,这个过程就是值绑定。这里不再给出具体的做法,因为还是v-bind的使用过程。

v-model修饰符 - lazy

lazy修饰符是什么作用呢?
默认情况下,v-model在进行双向绑定时,绑定的是input事件,那么会在每次内容输入后就将最新的值和绑定的属性进行同步。如果我们在v-model后跟上lazy修饰符,那么会将绑定的事件切换为 change 事件,只有在提交时(比如回车)才会触发。

v-model修饰符 - number

我们先来看一下v-model绑定后的值是什么类型的,如下:message总是string类型,即使在我们设置type为number也是string类型。

如果我们希望转换为数字类型,那么可以使用 .number 修饰符。

另外,逻辑判断时,可以转化的情况下,会隐式的自动将一个string类型成一个number类型再来进行判断(隐式转化)。

v-model修饰符 - trim

如果要自动过滤用户输入的首尾空白字符,可以给v-model添加 trim 修饰符:

v-mode组件上使用

v-model也可以使用在组件上,Vue2版本和Vue3版本有一些区别。具体的使用方法,后面讲组件化开发再具体学习。

相关文章

  • Vue3-表单绑定

    v-model的基本使用 表单提交是开发中非常常见的功能,也是和用户交互的重要手段,比如用户在登录、注册时需要提交...

  • Gin-获取请求参数——表单实体绑定

    GET的表单实体绑定获取 POST的表单实体绑定获取 JSON类型参数的表单实体绑定获取

  • JSTL学习收藏

    1 下拉表单绑定

  • Element-UI表单验证

    校验规则 表单通过rules属性绑定校验规则对象,表单项通过prop属性绑定具体校验规则 注意校验的字段必须和表单...

  • 【Vue】表单输入绑定与组件基础

    1. 表单输入绑定 v-model指令在表单input、textarea、selelct元素上创建双向数据绑定。v...

  • 2017-07-14

    vue中,表单组件的数据双向绑定,不仅跟表单控件类型有关,还跟绑定的数据类型有关。 看来是表单控件类型去决定数据类...

  • Vue.js教程_7

    表单输入绑定- v-model 基础语法 v-model指令在表单 、 、 元素上创建双向数据绑定。根据控件类型自...

  • Vue表单输入绑定和样式绑定

    一、表单输入绑定 用 v-model 指令在表单 、 及 元素上创建双向数据绑定。它会根据控件类型自动选取正...

  • 09-vue.js-表单输入绑定

    表单输入绑定 基础用法 可以用 v-model 指令在表单 、 及 元素上创建双向数据绑定。它会根据控件类...

  • 渲染Web视图——使用Spring的表单绑定JSP库

    将表单绑定到模型上 Sping的表单绑定JSP标签库与原生的HTML标签库的区别在于他们会绑定模型中的一个对象,能...

网友评论

      本文标题:Vue3-表单绑定

      本文链接:https://www.haomeiwen.com/subject/kyvcyrtx.html