文章目录
前言
你可以用 v-model
指令在表单 <input>
、<textarea>
及 <select>
元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但 v-model
本质上不过是语法糖。它负责监听用户的输入事件来更新数据,并在某种极端场景下进行一些特殊处理。手动连接值绑定和更改事件监听器可能会很麻烦,v-model
指令简化了这一步骤。
提示:以下是本篇文章正文内容,下面案例可供参考
一、表单数据绑定v-model
- 若:类型为文本输入本框
<input type="text"/>
,则v-model收集的是value值,用户输入的就是value值 - 若:类型为单选框
<input type="radio"/>
,则v-model收集的是value值,且要给标签配置value值 - 若:类型为复选框
<input type="checkbox"/>
(1).没有配置input的value属性,那么收集的就是checked(勾选 or 未勾选,是布尔值)
(2).配置input的value属性:
①v-model的初始值是非数组,那么收集的就是checked(勾选 or 未勾选,是布尔值)
②v-model的初始值是数组,那么收集的的就是value组成的数组 - 注意:v-model的三个修饰符:
lazy:失去焦点再收集数据
number:输入字符串转为有效的数字
trim:输入首尾空格过滤
<head>
<meta charset="UTF-8" />
<title>表单数据绑定</title>
<script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
<!-- 准备好一个容器-->
<div id="root">
<form @submit.prevent="func">
用户:<input type="text" v-model.trim="userInfo.username"> <br/><br/>
密码:<input type="password" v-model="userInfo.password"> <br/><br/>
年龄:<input type="number" v-model.number="userInfo.age"> <br/><br/>
性别:
男<input type="radio" name="sex" v-model="userInfo.sex" value="male" >
女<input type="radio" name="sex" v-model="userInfo.sex" value="female" > <br/><br/>
爱好:
抽烟<input type="checkbox" v-model="userInfo.hobby" value="smoke">
喝酒<input type="checkbox" v-model="userInfo.hobby" value="drink">
烫头<input type="checkbox" v-model="userInfo.hobby" value="hot-hair">
<br/><br/>
所属校区
<select v-model="userInfo.city">
<option value="">学校所在地址</option>
<option value="beijing">北京</option>
<option value="shanghai">上海</option>
<option value="shenzhen">深圳</option>
<option value="wuhan">武汉</option>
</select>
<br/><br/>
其他信息:
<textarea v-model.lazy="userInfo.other"></textarea> <br/><br/>
<input type="checkbox" v-model="userInfo.agree">阅读并接受<a href="http://www.baidu.com">《用户协议》</a>
<button>提交</button>
</form>
</div>
</body>
<script type="text/javascript">
Vue.config.productionTip = false //阻止提示
// 创建实例
new Vue({
el:'#root',
data:{
userInfo:{
username:'',
password:'',
age:18,
sex:'',
hobby:[],
city:'beijing',
other:'',
agree:''
}
},
methods: {
func(){
console.log('输出数据...',JSON.stringify(this.userInfo))
}
}
})
</script>
!!!注意:当输入的是文本框时候,v-model默认绑定的就是value值,可以进行实时页面数据更新。
!!!注意:当输入框为单选框时,如果不写value,则默认v-mode默认收集的是null值,所以必须需要给标签配置value值。
!!!注意:当输入框为复选框时,v-model绑定的初始值是非数组,默认绑定的是checked对应的布尔型值。
总结
1.trim修饰符
如果要自动过滤用户输入的首尾空白字符,可以给 v-model
添加 trim
修饰符
2.number修饰符
限定输入字符串为有效的数字
3.lazy修饰符
在默认情况下,v-model
在每次 input
事件触发后将输入框的值与数据进行同步 。你可以添加 lazy
修饰符,从而转为在 change
事件之后进行同步