Vue笔记-Day04-02(表单数据的收集)

4.2 收集表单数据:

若:<input type="text">,则v-model收集的是value值,用户输入的就是value值;
若:<input type="radio">,则v-model收集的是value值,且要给标签配置value值;
若:<input type="checkbox">
1.没有配置input的value属性,那么收集的是boolean的checked(是否勾选)
2.配置input的value属性:
(1)v-model的初始值不是数组:则收集依然是checked;
(2)v-model的初始值是数组:则收集的就是value组成的数组;
备注:v-model的三个修饰符:
lazy:失去焦点后再收集数据;
number:输入字符转为有效数字;
trim:输入首尾空格过滤;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>收集表单数据</title>
    <script type="text/javascript" src="../js/vue.js"></script>
    <style>
        li{
            line-height: 40px;
            list-style: none;
        }
    </style>
</head>
<body>
<div id="root">
    <form @submit.prevent="demo">
        <ul>
            <li> <label for="account">account:</label><input type="text" id="account" v-model.trim="userInfo.account"></li>
            <li><label for="password">password:</label><input type="password" id="password" v-model:value="userInfo.password"></li>
            <li><label for="age">age:</label><input type="number" id="age" v-model.number="userInfo.age"></li>
            <li>gender:
<!--             radio   -->
            man<input type="radio" name="gender" v-model="userInfo.gender" value="male">
            woman<input type="radio" name="gender" v-model="userInfo.gender" value="female">
            </li>
            <li>hobbies:
<!--            checkbox    -->
            eat<input type="checkbox" v-model="userInfo.hobby" value="eat">
            drink<input type="checkbox" v-model="userInfo.hobby" value="drink">
            play game<input type="checkbox" v-model="userInfo.hobby" value="play game">
            </li>
            <li>school
                <select v-model="userInfo.city">
<!--                    -->
                    <option value="">select you school</option>
                    <option value="New York">New York</option>
                    <option value="Bei Jing">Bei Jing</option>
                    <option value="Shang Hai">Shang Hai</option>
                    <option value="Paris">Paris</option>
                </select>
            </li>
            <li>
                other:
                <textarea v-model.lazy="userInfo.other"></textarea>
            </li>
            <li>
                阅读并同意用户协议和隐私政策<input type="checkbox" v-model="userInfo.agree">
            </li>
            <li>
                <button value="submit">submit</button>
            </li>
        </ul>


    </form>
</div>

    <script type="text/javascript">
        Vue.config.productionTip = false

        const vm = new Vue({
            el:'#root',
            data:{
                userInfo:{
                    account:'',
                    password:'',
                    age:'',
                    gender:'male',
                    hobby:[],
                    city:'',
                    other:'',
                    agree:false,
                }
            },
            methods:{
                demo(){
                    alert("submit");
                    console.log(JSON.stringify(this.userInfo))
                }
            }
        })

    </script>

</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值