Vue表单实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>表单提交实例</title>
</head>
<style>
    *{
        margin: 10px;
    }
   
</style>
<body>
    <form action="" id="form1" @submit.prevent="demo">
       账号:
       <!-- trim用于清除输入文本第一个和最后一个非空格字符前后的所有空格 -->
        <input type="text " v-model.trim="account">
        <br/>
        密码:
        <input type="text " v-model="accesskey">
        <br/>
        年龄:
        <!-- v-model.number将输入的字符自动转换为数字,number用于限制输入文本类型 -->
        <input type="number" v-model.number="age">
        <br/>
        性别:  <br/>
        <!-- name属性用于告诉表单,俩按钮是一组,只能选一个 -->
        <!-- v-model只能用于有value值的对象,要手动赋值 -->
       男<input type="radio" name="sex" value="male" v-model="sex"> 女<input type="radio" name="sex" value="female" v-model="sex">
       <br/>
       爱好: <br/>
       <!-- 对于多项选择框,需要指定value值,监控对象,并且监控对象得是数组 -->
       吃饭<input type="checkbox" v-model="hobby" value="吃饭">
       睡觉<input type="checkbox" v-model="hobby" value="睡觉">
       打豆豆<input type="checkbox" v-model="hobby" value="打豆豆">
       <br/>
       所属校区:
       <select v-model="location">
        <option value="">请选择校区</option>
        <option value="a">A区</option>
        <option value="b">B区</option>
       </select>
       <br/>
       其他信息:
       <br/>
       <!-- 延缓获取信息,当文本框失去焦点时更新内容 -->
       <textarea v-model.lazy="others"></textarea>    
       <br/>
       <input type="checkbox" v-model="agree" >阅读并同意 <a href="http://www.bilibili.com" >用户协议</a>
       <br/>
       <button @click="check">提交</button>


    </form>
</body>
<script src="../开发版/vue.js"></script>
<script>
    var vm=new Vue({
        el:"#form1",
        data:{
            account:"",
            accesskey:"",
            age:18,
            sex:"male",
            hobby:[],
            location:"a",
            others:"",
            agree:false
        },
        methods: {
            demo(){
                
                console.log(JSON.stringify(vm._data));
            },
            check(event){
                console.log(this.agree);
                if(!this.agree){
                    alert("请阅读并同意<<用户协议>>!");
                    // 用于阻止表单提交的默认行为
                    event.preventDefault();
                }
            }
        }

    })
</script>
</html>

此实例仅判断了是否勾选了阅读用户协议,其他信息的有效性暂未验证

上一篇:Vue变化侦听


下一篇:Vue 监测数据改变的原理