收集表单数据:
- 若<input type="text">,则v-model收集的是value值,用户输入的就是value值
- 若<input type="radio">,则v-model收集的是value值,且要给标签配置value值
- 若<input type="checkbox">
- 没有配置input的value属性,那么收集就是checked(勾选或未勾选,是布尔值)
- 配置input的value属性:
(1)v-model的初始值是非数组,那么收集的就是checked(勾选或未勾选,是布尔值)
(2)v-model的初始值是数组,那么收集的就是value组成的数组
备注:v-model的三个修饰符:
lazy:失去焦点的时候再收集数据
number:输入字符串转为有效的数字
trim;输入首位空格过滤
<template> <div> <form @submit.prevent="getFormData"> 账号:<input type="text" v-model="account"><br><br> 密码:<input type="text" v-model="password"><br><br> <!-- 控制输入的信息为数字类型,最后再转换为数值型 --> 年龄:<input type="number" v-model.number="age"><br><br> 性别:男<input type="radio" name="sex" value="man" v-model="sex"> 女<input type="radio" name="sex" value="woman" v-model="sex"> <br><br> 爱好:学习<input type="checkbox" value='study' v-model="hobby"> 打游戏<input type="checkbox" value="games" v-model="hobby"> 吃饭<input type="checkbox" value="food" v-model="hobby"> <br><br> 所属校区: <select v-model="city"> <option value="">请选择校区</option> <option value="">北京</option> <option value="">上海</option> <option value="">深圳</option> </select> <br><br> 其他信息: <!-- change事件发生后才出现回调 --> <textarea v-model.lazy="other" cols="30" rows="10"></textarea> <br><br> <input type="checkbox" v-model='agree'> 阅读并接受<a href="http://www.baidu.com">《用户协议》</a> <br><br> <button >提交</button> </form> </div> </template> <script setup> import {ref,reactive} from 'vue' let account=ref('') let password=ref('') let sex=ref('man') let age=ref() let hobby=ref([]) let city=ref('') let other=ref('') let agree=ref('') const getFormData=()=>{ console.log(account,password,sex,hobby,city,other,agree); } </script>
标签:收集,number,value,表单,let,model,ref From: https://www.cnblogs.com/shuchenhao/p/16951720.html