在Vue进行前端开发中,表单的输入是基础且常见的功能,本文以一个简单的小例子,简述v-model数据绑定的用法,仅供学习分享使用,如有不足,还请指正。
基础用法
你可以用 v-model 指令在表单 、 及 元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但 v-model 本质上不过是语法糖。它负责监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。v-model 会忽略所有表单元素的 value、checked、selected attribute 的初始值而总是将 Vue 实例的数据作为数据来源。你应该通过 JavaScript 在组件的 data 选项中声明初始值。v-model 在内部为不同的输入元素使用不同的属性并抛出不同的事件,如下所示:
text 和 textarea 元素使用 value 属性和 input 事件;
checkbox 和 radio 使用 checked 属性和 change 事件;
select 字段将 value 作为 prop 并将 change 作为事件。
文本
通过v-model将input的value值和msg进行双向绑定,如下所示:
1
2
Message is: {{ msg }}
多行文本
通过v-model将textarea的value值和msg进行双向绑定,如下所示:
1 多行信息如下:
2 {{ msg }}
3
注意:white-space: pre-line;表示:合并空白符序列,但是保留换行符。
在文本区域插值 ({{text}}) 并不会生效,应用 v-model 来代替。
复选框
单个复选框,绑定到布尔值,如下所示:
1
2 {{ checked }}
注意:for="checkbox" 表示将label和input进行绑定。v-model="checked"中的checked为定义的属性。
多个复选框,绑定到同一个数组:
1
2
3 Jack
4
5 John
6
7 Mike
8
9 选种名称: {{ checkedNames }}
10