Vue学习:v-model绑定文本框、单选按钮、下拉菜单、复选框等

v-model指令可以在组件上使用以实现双向绑定,之前学习过v-model绑定文本框和下拉菜单,今天把表单的几个控件单选按钮radio、复选框checkbox、多行文本框textarea都试着绑定了一下。

一、单行文本框和多行文本框

html 复制代码
<p>1.单行文本框</p>
用户名:<input type="text" v-model="inputMessage">
<p>您的用户名是:{{inputMessage}}</p>
<p>2.多行文本框</p>
<textarea v-model="textMessage" placeholder="请留言" rows="4" cols="80"></textarea>
<p>您的留言是:{{textMessage}}</p>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                inputMessage: '',
                textMessage: '',
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

二、单选按钮和下拉菜单

html 复制代码
<p>3.单选按钮</p>
<input type="radio" name="certificate" value="高" v-model="level"> 高级
<input type="radio" name="certificate" value="中" v-model="level"> 中级
<input type="radio" name="certificate" value="初" v-model="level"> 初级
<p>证书级别是:{{level}}</p>
<p>4.下拉菜单</p>
 所在城市:
 <select v-model="city">
   <option value="">请选择</option>
   <option value="beijing">北京</option>
   <option value="shanghai">上海</option>
   <option value="guangzhou">广州</option>
   <option value="shenzhen">深圳</option>
 </select>
 <p>所在城市是:{{city}}</p>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                level: '高',
                city: '',
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

三、复选框

html 复制代码
<p>5-1.复选框</p>
        <div>
            字节跳动:
            <input type="checkbox" v-model="byteDance" value="抖音">抖音
            <input type="checkbox" v-model="byteDance" value="西瓜视频">西瓜视频
            <input type="checkbox" v-model="byteDance" value="今日头条">今日头条
            <p>选中的复选框数量:{{ byteDance.length }}</p>
            <p>选中的复选框项:{{ byteDance }}</p>
        </div>
        <p>5-2.复选框(使用 v-for)生成复选框</p>
        <div>
            业余爱好:
            <label v-for="item in checks" :key="item.id">
                <input type="checkbox" v-model="checkOptions" :value="item.name">
                {{ item.name }}
            </label>
            <p>选中的复选框数量:{{ checkOptions.length }}</p>
            <p>选中的复选框项:{{ checkOptions }}</p>
        </div>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                byteDance:[],
                checks: [
                    { id: 1, name: '游泳' },
                    { id: 2, name: '网球' },
                    { id: 3, name: '滑板' }
                ],
                checkOptions: [],
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

完整代码如下:

html 复制代码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>v-model绑定input、textarea、radio、select、checkbox</title>
    <!--引入vue库-->
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>

<body>
    <div id="app"> <!--挂载点-->
        <p>1.单行文本框</p>
        用户名:<input type="text" v-model="inputMessage">
        <p>您的用户名是:{{inputMessage}}</p>
        <p>2.多行文本框</p>
        <textarea v-model="textMessage" placeholder="请留言" rows="4" cols="80"></textarea>
        <p>您的留言是:{{textMessage}}</p>
        <p>3.单选按钮</p>
        <input type="radio" name="certificate" value="高" v-model="level"> 高级
        <input type="radio" name="certificate" value="中" v-model="level"> 中级
        <input type="radio" name="certificate" value="初" v-model="level"> 初级
        <p>证书级别是:{{level}}</p>
        <p>4.下拉菜单</p>
        所在城市:
        <select v-model="city">
            <option value="">请选择</option>
            <option value="beijing">北京</option>
            <option value="shanghai">上海</option>
            <option value="guangzhou">广州</option>
            <option value="shenzhen">深圳</option>
        </select>
        <p>所在城市是:{{city}}</p>
        <p>5-1.复选框</p>
        <div>
            字节跳动:
            <input type="checkbox" v-model="byteDance" value="抖音">抖音
            <input type="checkbox" v-model="byteDance" value="西瓜视频">西瓜视频
            <input type="checkbox" v-model="byteDance" value="今日头条">今日头条
            <p>选中的复选框数量:{{ byteDance.length }}</p>
            <p>选中的复选框项:{{ byteDance }}</p>
        </div>
        <p>5-2.复选框(使用 v-for)生成复选框</p>
        <div>
            业余爱好:
            <label v-for="item in checks" :key="item.id">
                <input type="checkbox" v-model="checkOptions" :value="item.name">
                {{ item.name }}
            </label>
            <p>选中的复选框数量:{{ checkOptions.length }}</p>
            <p>选中的复选框项:{{ checkOptions }}</p>
        </div>
    </div>
</body>

<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                inputMessage: '',
                textMessage: '',
                level: '高',
                city: '',
                byteDance:[],
                checks: [
                    { id: 1, name: '游泳' },
                    { id: 2, name: '网球' },
                    { id: 3, name: '滑板' }
                ],
                checkOptions: [],
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")          //挂载vueApp
    console.log(vm.$data.inputMessage)       //输出data函数定义的inputMessage属性值 
</script>

</html>
相关推荐
一位搞嵌入式的 genius2 小时前
从 ES6 到 ESNext:JavaScript 现代语法全解析(含编译工具与实战)
前端·javascript·ecmascript·es6
linweidong4 小时前
C++ 模块化编程(Modules)在大规模系统中的实践难点?
linux·前端·c++
leobertlan7 小时前
2025年终总结
前端·后端·程序员
子兮曰7 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
Howrun7778 小时前
VSCode烦人的远程交互UI讲解
ide·vue.js·vscode
百锦再8 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
莲华君8 小时前
React快速上手:从零到项目实战
前端·reactjs教程
百锦再8 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
易安说AI8 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
盐焗西兰花9 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos