收集表单数据(包括输入number型如何保证输出还是number型)

收集表单数据:

  • 若<input type="text">,则v-model收集的是value值,用户输入的就是value值
  • 若<input type="radio">,则v-model收集的是value值,且要给标签配置value值
  • 若<input type="checkbox">
    1. 没有配置input的value属性,那么收集就是checked(勾选或未勾选,是布尔值)
    2. 配置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>

 

posted @ 2022-12-05 10:47  终究还是避免不了遗憾  阅读(29)  评论(0编辑  收藏  举报