Vue学习教程-12表单数据绑定


前言

你可以用 v-model 指令在表单 <input><textarea><select> 元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但 v-model 本质上不过是语法糖。它负责监听用户的输入事件来更新数据,并在某种极端场景下进行一些特殊处理。手动连接值绑定和更改事件监听器可能会很麻烦,v-model指令简化了这一步骤。


提示:以下是本篇文章正文内容,下面案例可供参考

一、表单数据绑定v-model

  1. 若:类型为文本输入本框 <input type="text"/>,则v-model收集的是value值,用户输入的就是value值
  2. 若:类型为单选框<input type="radio"/>,则v-model收集的是value值,且要给标签配置value值
  3. 若:类型为复选框<input type="checkbox"/>
    (1).没有配置input的value属性,那么收集的就是checked(勾选 or 未勾选,是布尔值)
    (2).配置input的value属性:
    ①v-model的初始值是非数组,那么收集的就是checked(勾选 or 未勾选,是布尔值)
    ②v-model的初始值是数组,那么收集的的就是value组成的数组
  4. 注意: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 事件之后进行同步

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

番茄番茄君

你的顾虑将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值