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

news2024/11/13 9:36:12

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

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

<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>
<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>

运行效果如下。
在这里插入图片描述

二、单选按钮和下拉菜单

<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>
<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>

运行效果如下。
在这里插入图片描述

三、复选框

<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>
<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>

运行效果如下。
在这里插入图片描述
完整代码如下:

<!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>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2118520.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

程序员日志之DNF编年史

目录 传送门正文日志1、概要2、超高度总结概括3、详细编年史3.1、大背景3.2、冒险家 传送门 SpringMVC的源码解析&#xff08;精品&#xff09; Spring6的源码解析&#xff08;精品&#xff09; SpringBoot3框架&#xff08;精品&#xff09; MyBatis框架&#xff08;精品&…

YOLOv5改进 | 模块缝合 | C3 融合RFCAConv增强感受野空间特征 【二次融合 小白必备】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 专栏目录 &#xff1a;《YOLOv5入门 改…

飞牛fnOS安装KDE桌面

飞牛fnOS安装KDE桌面 这段时间新出的nas系统飞牛os真不错&#xff0c;基于debian的可折腾性又高了不少&#xff0c;今天就来给这个系统装个桌面&#xff0c;插上显示器也能当个电脑自己进自己的管理界面&#xff0c;播放下视频&#xff0c;上上网啥的。 文章目录 飞牛fnOS安装…

问卷调查,动静IP应该如何选择?

在探讨问卷调查这一领域时&#xff0c;选择使用动态IP还是静态IP&#xff0c;成为了许多从业者及市场研究者面临的重要决策&#xff0c;它不仅关乎数据收集的效率与质量&#xff0c;还直接影响到问卷调查的合法性与安全性。本文将从多个维度深入分析这两种IP类型的优劣&#xf…

python-网页自动化(三)

如果遇到使用 ajax 加载的网页&#xff0c;页面元素可能不是同时加载出来的&#xff0c;这个时候尝试在 get 方法执行完 成时获取网页源代码可能并非浏览器完全加载完成的页面。所以&#xff0c;这种情况下需要设置延时等待一定时间&#xff0c;确保全部节点都加载出来。 那么&…

每日一练8:dd爱框框(含链接)

1.链接 登录—专业IT笔试面试备考平台_牛客网 2.题目 3.代码 #include<iostream> #include<vector>using namespace std;const int N 1e7 5;int n,x;vector<int> v(N);int main() {cin >> n >> x;for(int i 0; i < n;i) cin >> v…

服务端性能测试:行业流行性能监控工具介绍

行业流行性能监控工具有哪些 Linux 自带命令 Vmstat&#xff0c;Top 等 Nmon Collectd InfluxDB Grafana Prometheus Grafana 行业流行性能监控工具的介绍 Linux 自带命令 Vmstat&#xff0c;Top 等 vmstat 和 top 都是 Linux 系统自带的命令&#xff0c;提供了实时的…

每日一练:轮转数组

一、题目要求 给定一个整数数组 nums&#xff0c;将数组中的元素向右轮转 k 个位置&#xff0c;其中 k 是非负数。 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右轮转 3 步: …

hive时间函数

一、随机示例&#xff08;想到哪里写哪里&#xff09; 1.系统时间函数 查询 select current_timestamp --当前格式化时间,current_date --当前格式化日期,unix_timestamp() --当前unix时间戳 结果&#xff1a; 2.时间函数转换 查询 --将时间戳转化为格式化时间 sel…

微片水凝胶如何用于4D生物打印?快来了解一下!

大家好&#xff0c;今天我们来聊聊一项4D 活细胞生物打印技术——《Jammed Micro-Flake Hydrogel for 4D Living Cell Bioprinting》发表于《Advanced Materials》。在组织器官再生应用中&#xff0c;构建具有复杂几何形状和功能的载细胞结构至关重要。而水凝胶基4D生物墨水的发…

免费 U 盘数据恢复 - 用 4 种免费方法从随身U 盘恢复文件

如何在不使用软件的情况下从 USB 驱动器恢复已删除的文件&#xff1f;如何取消删除 USB 闪存驱动器&#xff1f;首先&#xff0c;不要对拇指驱动器进行任何进一步的更改。然后下载奇客数据恢复&#xff0c;这是一款免费的U 盘恢复工具&#xff0c;能够从各种问题中恢复笔式驱动…

网络层协议-ARP协议

网络层协议-ARP协议 1&#xff09;概述 ARP&#xff1a;地址解析协议&#xff0c;作用&#xff1a;根据IP地址查询MAC地址 数据包发送前需要进行封包&#xff0c;在数据链路层需要封装源mac地址是自己的mac&#xff0c;目的mac地址是别人&#xff0c;但是不知道别人的mac地址…

西门子WinCC开发笔记(一):winCC西门子组态软件介绍、安装

文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/142060535 长沙红胖子Qt&#xff08;长沙创微智科&#xff09;博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、Op…

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

&#x1f308;个人主页&#xff1a; 南桥几晴秋 &#x1f308;C专栏&#xff1a; 南桥谈C &#x1f308;C语言专栏&#xff1a; C语言学习系列 &#x1f308;Linux学习专栏&#xff1a; 南桥谈Linux &#x1f308;数据结构学习专栏&#xff1a; 数据结构杂谈 &#x1f308;数据…

为什么RAG对下一代AI开发至关重要

RAG&#xff08;检索增强生成&#xff09;是一种突破性技术&#xff0c;它将信息检索与文本生成相结合&#xff0c;以提高人工智能系统的知识和准确性。利用 RAG 可以帮助开发人员确保应用程序响应具有最丰富的上下文和准确性&#xff0c;因为它可以访问原始模型训练之外的精选…

解决samba无权限创建文件问题

将我服务器利用samba工具映射到到电脑后&#xff0c;没有权限在特定的文件里写文件&#xff0c;比如在mcu这个文件夹里面没有写文件的权限。 查看mcu文件夹的用户属性&#xff0c;属于root属性。 rootzwzn2064-CVN-Z690D5-GAMING-PRO:/home/zwzn2064# ls -ll total 9714860 dr…

MySQL 自学笔记(入门基础篇,含示例)

目录 一、基础1.变量2.运算符 二、数据库与表1.创建数据库2.表的增删与修改&#xff08;1&#xff09;表的创建与删除&#xff08;2&#xff09;表的修改&#xff08;3&#xff09;其他指令 3.属性约束4.数据操作&#xff08;1&#xff09;数据更新&#xff08;2&#xff09;数…

Hive任务优化参数整理

Hive本身是个基于hdfs的结构化数据管理工具&#xff0c;虽然在后面的发展中允许底层接入其他的数据源&#xff0c;比如第三方数据服务这种基础架构&#xff0c;但是它从立意上来说&#xff0c;它不适合用来做高性能查询引擎&#xff0c;反而在传统离线数据仓库中它有着自身的优…

在连通无向图中寻找正反向各通过每条边一次的路径(中国邮递员问题)

在连通无向图中寻找正反向各通过每条边一次的路径(中国邮递员问题) 引言问题定义算法思路具体步骤第一步:找出所有奇度顶点第二步:将奇度顶点配对,并添加最短路径第三步:构造欧拉回路伪代码C语言实现引言 在图论中,中国邮递员问题(Chinese Postman Problem, CPP)是一…

高精度E4990A参数资料keysight是德e4990a阻抗分析仪

Keysight E4990A 阻抗分析仪的规格&#xff1a; 工作频率选项&#xff1a; 20 Hz 至 10 MHz20 Hz 至 20 MHz20 Hz 至 30 MHz20 Hz 至 50 MHz20 Hz 至 120 MHz选项分别为 010 / 020 / 030 / 050 / 120 测量参数&#xff1a;lZl、lYl、O、R、X、G、B、L、C、D、Q、复合 Z、复合…