【vue-5】双向数据绑定v-model及修饰符

单向数据绑定:当数据发生改变时,视图会自动更新,但当用户手动更改input的值,数据不会自动更新;

双向数据绑定:当数据发生改变时,视图会自动更新,但当用户手动更改input的值,数据也会自动更新。

一、v-model

1、双向数据绑定

复制代码
双向数据绑定<input type="text" v-model="web.text">

2、单选框

复制代码
<input type="radio" v-model="web.radio" value="星期一">星期一
<input type="radio" v-model="web.radio" value="星期二">星期二

3、复选框

复制代码
<input type="checkbox" v-model="web.checkbox" value="星期一">星期一
<input type="checkbox" v-model="web.checkbox" value="星期二">星期二
<input type="checkbox" v-model="web.checkbox" value="星期三">星期三

4、记住密码

复制代码
<input type="checkbox" v-model="web.remember">记住密码

5、下拉框

对于<select>,v-model绑定的是select元素中选中的项。

复制代码
<select v-model="web.select">
    <option value="">请选择</option>
    <option value="星期一">星期一</option>
    <option value="星期二">星期二</option>
    <option value="星期三">星期三</option>
</select>

完整示例代码:

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <!-- <script src="vue.global.js"></script> -->
    
</head>
<body>
    <div id="app">
        <h3>文本框:{{web.text}}</h3>
        <h3>单选框:{{web.radio}}</h3>
        <h3>复选框:{{web.checkbox}}</h3>
        <h3>记住密码:{{web.remember}}</h3>
        <h3>下拉框:{{web.select}}</h3>
        <hr>
        单向数据绑定<input type="text" :value="web.text"><br>
        双向数据绑定<input type="text" v-model="web.text">
        <hr>
        <!-- 单选框 -->
        <input type="radio" v-model="web.radio" value="星期一">星期一
        <input type="radio" v-model="web.radio" value="星期二">星期二
        <hr>
        <!-- 复选框 -->
        <input type="checkbox" v-model="web.checkbox" value="星期一">星期一
        <input type="checkbox" v-model="web.checkbox" value="星期二">星期二
        <input type="checkbox" v-model="web.checkbox" value="星期三">星期三
        
        <hr>
        <!-- 记住密码 -->
        <input type="checkbox" v-model="web.remember">记住密码

        <hr>
        <!-- 下拉框 -->
        <select v-model="web.select">
            <option value="">请选择</option>
            <option value="星期一">星期一</option>
            <option value="星期二">星期二</option>
            <option value="星期三">星期三</option>
        </select>

    </div>
    <script type="module">
        import {createApp, reactive} from './vue.esm-browser.js'
        // const {createApp, reactive} = Vue
        createApp({
            // setup选项,用于设置响应式数据和方法等
            setup(){ 
                const web = reactive({
                    text:"denglu.com",
                    radio:"",
                    checkbox:[],
                    remember:false,
                    select:""
                })
                
                return{
                    web     
                }
            }
        }).mount("#app")
        // mount为挂载
    </script>
</body>
</html>

二、v-model修饰符

实现功能:在失去焦点或按下回车键之后再渲染。

复制代码
<input type="text" v-model.lazy="web.url">

实现功能:输入框的值转换为数字类型

复制代码
<input type="text" v-model.number="web.user">

实现功能:去除收尾空格

复制代码
<input type="text" v-model.trim="web.url">
相关推荐
昔人'6 小时前
html`<mark>`
前端·javascript·html
云中雾丽6 小时前
Flutter主流的本地存储方案
前端
ss2736 小时前
手写Spring第7弹:Spring IoC容器深度解析:XML配置的完整指南
java·前端·数据库
前端拿破轮7 小时前
从0到1搭一个monorepo项目(二)
前端·javascript·面试
止观止7 小时前
XSS 攻击详解:原理、类型与防范策略
前端·xss
SuperherRo7 小时前
JS逆向-安全辅助项目&Yakit热加载&魔术方法&模版插件语法&JSRpc进阶调用&接口联动
javascript·安全·yakit·jsrpc·热加载
用户47949283569157 小时前
用|运算符写管道?Symbol.toPrimitive让JavaScript提前用上|>语法
前端·javascript
知识分享小能手7 小时前
uni-app 入门学习教程,从入门到精通,uni-app 基础知识详解 (2)
前端·javascript·windows·学习·微信小程序·小程序·uni-app
文心快码BaiduComate8 小时前
限时集福!Comate挂件/皮肤上线,符(福)气掉落中~
前端·后端·程序员
勇敢di牛牛8 小时前
vue3 + mars3D 三分钟画一个地球
前端·vue.js