vue之数据的双向绑定

本文深入解析 Vue 框架中的 v-model 指令,介绍了其在表单元素上的作用,通过监听 input 事件和 value 值实现双向数据绑定。示例代码展示了 v-model 在不同表单元素(如 input、select、checkbox、radio 和 textarea)上的用法,帮助理解 v-model 的底层原理和实际应用。
摘要由CSDN通过智能技术生成

vue指令:v-model

作用于:表单元素上(提供视图 | 页面上数据的修改空间)

底层原理:

        input事件 + value值

    <div id="app">
        <input type="text" :value="msg" v-on:input="handle">
        <!-- <input type="text" :value="msg" v-on:input="msg=$event.target.value"> -->
        <div>{{ msg }}</div>
    </div>
    <script src="../vue_v2.6.14.js"></script>
    <script>
        const vm = new Vue({
            el: '#app',
            data: {
                msg: "hello"
            },
            methods: {
                handle(e) {
                    this.msg = e.target.value;
                }
            }
        })

常见表单元素的双向绑定:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title></title>
</head>

<body>
    <div id="app">
        <!-- input  -->
        <input type="text" v-model="msg">
        {{ msg }}
        <hr>

        <!-- select  -->
        <select name="" id="" v-model="selectMsg">
            <option value="qd">前端</option>
            <option value="hd">后端</option>
            <option value="ui">UI</option>
        </select>
        {{ selectMsg }}
        <hr>

        <!-- 复选框 checkbox -->
        <input type="checkbox" name="flower" value="carnation" v-model="checkMsg">康乃馨
        <input type="checkbox" name="flower" value="rose" v-model="checkMsg">玫瑰
        <input type="checkbox" name="flower" value="lily" v-model="checkMsg">百合
        {{ checkMsg }}
        <hr>

        <!-- 单选框 radio -->
        <input type="radio" name="男" value="0" v-model="radioMsg">男
        <input type="radio" name="女" value="1" v-model="radioMsg">女
        {{ radioMsg }}
        <hr>

        <!-- 文本域  -->
        <textarea name="" id="" cols="30" rows="10" v-model="text"></textarea>
        <div v-html="text"></div>
        <hr>

    </div>
    <script src="../vue_v2.6.14.js"></script>
    <script>
        const vm = new Vue({
            el: '#app',
            data: {
                msg: "lifen", // 与input框的value绑定
                selectMsg: "ui", // 与option的vale绑定
                // checkMsg: "", // 值为空字符串时,默认为false-未选中的状态
                checkMsg: [], // 
                // radioMsg: [], // 
                radioMsg: '', // 
                text: '' // 
            },
            methods: {

            }
        })
    </script>
</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值