Vue 3 30天精进之旅:Day 06 - 表单输入绑定
引言
在前几天的学习中,我们探讨了事件处理的基本概念及其在Vue中的应用。今天,我们将进一步了解Vue的表单输入绑定。这是构建用户交互式应用的核心部分,使得我们能够方便地处理用户输入并实时更新数据。本文将介绍如何在Vue中实现单向和双向数据绑定、表单控件的处理以及高级用法。
1. Vue中的数据绑定
Vue.js 提供了简单而灵活的数据绑定机制,使得将DOM元素与Vue实例的数据保持同步变得容易。我们可以通过v-model
指令来实现双向数据绑定。
1.1 单向绑定与双向绑定
- 单向绑定:数据从Vue实例流向视图。视图的变化不会影响数据。
- 双向绑定:数据和视图相互绑定,数据的变化会反映到视图中,视图的变化也会更新数据。
2. 使用v-model
实现双向绑定
v-model
是Vue中用于表单输入元素的双向绑定指令。它使得表单输入与Vue实例的数据保持同步。
2.1 基本用法
以下是一个使用v-model
的基本示例:
<template><div><label for="username">用户名:</label><input type="text" id="username" v-model="username" /><p>当前用户名: {{ username }}</p></div>
</template><script>
export default {data() {return {username: '',};},
};
</script>
在这个示例中,v-model
绑定了username
数据属性。用户在输入框中输入的内容会自动更新username
的值,同时username
的变化也会反映在界面上。
3. 处理不同类型的输入
Vue支持多种表单输入类型,包括文本框、单选框、复选框和下拉列表。下面是如何处理这些不同类型的输入。
3.1 文本框
文本框是最常用的输入控件,使用v-model
进行双向绑定非常简单,如上例所示。
3.2 单选框
对于单选框,可以使用v-model
来控制一个数据属性。以下是一个单选框的示例:
<template><div><label>性别:</label><label><input type="radio" value="男" v-model="gender" /> 男</label><label><input type="radio" value="女" v-model="gender" /> 女</label><p>选择的性别: {{ gender }}</p></div>
</template><script>
export default {data() {return {gender: '男', // 默认选择男};},
};
</script>
在这个示例中,单选框的值绑定到gender
数据属性。用户选择的性别会自动更新,而gender
的变化也会反映在界面上。
3.3 复选框
复选框的处理稍有不同,因为它允许多选。可以将复选框的值绑定到一个数组中:
<template><div><label>爱好:</label><label><input type="checkbox" value="足球" v-model="hobbies" /> 足球</label><label><input type="checkbox" value="篮球" v-model="hobbies" /> 篮球</label><label><input type="checkbox" value="游泳" v-model="hobbies" /> 游泳</label><p>选择的爱好: {{ hobbies }}</p></div>
</template><script>
export default {data() {return {hobbies: [], // 存储用户选择的爱好};},
};
</script>
在这个示例中,用户选择的复选框值会被存储在hobbies
数组中。
3.4 下拉列表
下拉列表也可以使用v-model
来实现双向绑定。以下是一个下拉列表的示例:
<template><div><label for="city">城市:</label><select id="city" v-model="selectedCity"><option value="北京">北京</option><option value="上海">上海</option><option value="广州">广州</option></select><p>选择的城市: {{ selectedCity }}</p></div>
</template><script>
export default {data() {return {selectedCity: '北京', // 默认选择北京};},
};
</script>
4. 处理表单提交
在Vue中,处理表单提交通常涉及到一个提交事件。你可以使用@submit.prevent
来阻止默认的表单提交行为,然后在处理函数中执行自定义逻辑。
4.1 表单提交示例
以下是一个简单的表单提交示例:
<template><form @submit.prevent="handleSubmit"><label for="username">用户名:</label><input type="text" id="username" v-model="username" /><button type="submit">提交</button></form>
</template><script>
export default {data() {return {username: '',};},methods: {handleSubmit() {alert(`提交的用户名是: ${this.username}`);// 这里可以添加进一步的逻辑,例如向服务器发送请求},},
};
</script>
在这个示例中,当用户提交表单时,会弹出一个提示框显示提交的用户名,而不会刷新页面。
5. 实践:构建一个用户注册表单
为了巩固今天的学习,我们将构建一个简单的用户注册表单,用户可以输入用户名、选择性别、爱好,并提交表单。
<template><div><h1>用户注册</h1><form @submit.prevent="handleSubmit"><label for="username">用户名:</label><input type="text" id="username" v-model="username" required /><label>性别:</label><label><input type="radio" value="男" v-model="gender" /> 男</label><label><input type="radio" value="女" v-model="gender" /> 女</label><label>爱好:</label><label><input type="checkbox" value="足球" v-model="hobbies" /> 足球</label><label><input type="checkbox" value="篮球" v-model="hobbies" /> 篮球</label><label><input type="checkbox" value="游泳" v-model="hobbies" /> 游泳</label><button type="submit">注册</button></form><h2>用户信息:</h2><p>用户名: {{ username }}</p><p>性别: {{ gender }}</p><p>爱好: {{ hobbies.join(', ') }}</p></div>
</template><script>
export default {data() {return {username: '',gender: '',hobbies: [],};},methods: {handleSubmit() {alert(`注册成功!用户名: ${this.username}, 性别: ${this.gender}, 爱好: ${this.hobbies.join(', ')}`);// 这里可以添加进一步的逻辑,例如向服务器发送请求},},
};
</script><style>
h1 {color: #42b983;
}
label {display: block;margin-top: 10px;
}
</style>
结论
今天,我们深入学习了Vue中的表单输入绑定,包括如何使用v-model
实现双向绑定、处理不同类型的输入控件以及表单提交的处理。通过构建用户注册表单,我们巩固了对表单处理的理解,并为后续更复杂的应用打下了基础。
相关文章:

Vue 3 30天精进之旅:Day 06 - 表单输入绑定
引言 在前几天的学习中,我们探讨了事件处理的基本概念及其在Vue中的应用。今天,我们将进一步了解Vue的表单输入绑定。这是构建用户交互式应用的核心部分,使得我们能够方便地处理用户输入并实时更新数据。本文将介绍如何在Vue中实现单向和双向…...

[创业之路-269]:《创业讨论会》- 系统之韵:从麻雀到5G系统的共通性探索
关键词: 从系统的角度,麻雀、人体系统、企业系统、软硬件系统、软件系统、通信系统、5G系统是类似的: 都有:内在看不见的规律、外在显性各种现象 都是:输入、处理、输出 都是:静态、要素、组成、结构、组织…...

使用C#对指定的MYSQL数据库进行备份以及常见问题
最近在开发过程中,需要做个MYSQL数据库的备份,大致总结了一下代码,以及常见的坑 string bakName "database" DateTime.Now.ToString("yyyyMMddHHmmss") ".sql";//备份后的数据库文件名var bakupFilePath &q…...

探索人工智能在计算机视觉领域的创新应用与挑战
一、引言 1.1 研究背景与意义 在科技飞速发展的当下,人工智能(Artificial Intelligence, AI)已然成为引领新一轮科技革命和产业变革的重要驱动力。作为 AI 领域的关键分支,计算机视觉(Computer Vision, CV࿰…...

Charles 4.6.7 浏览器网络调试指南:HTTPS抓包(三)
概述 在现代互联网应用中,网络请求和响应是服务交互的核心。对于开发者和测试人员来说,能够准确捕获并分析这些请求,是保证系统稳定性和性能的关键。Charles作为一个强大的网络调试工具,不仅可以捕获普通的HTTP请求,还…...

STM32 对射式红外传感器配置
这次用的是STM32F103的开发板(这里面的exti.c文件没有how to use this driver 配置说明) 对射式红外传感器 由一个红外发光二极管和NPN光电三极管组成,M3固定安装孔,有输出状态指示灯,输出高电平灯灭,输出…...

12 款开源OCR发 PDF 识别框架
2024 年 12 款开源文档解析框架的选型对比评测:PDF解析、OCR识别功能解读、应用场景分析及优缺点比较 这是该系列的第二篇文章,聚焦于智能文档处理(特别是 PDF 解析)。无论是在模型预训练的数据收集阶段,还是基于 RAG…...

危机13小时:追踪一场GitHub投毒事件
事件概要 自北京时间 2024.12.4 晚间6点起, GitHub 上不断出现“幽灵仓库”,仓库中没有任何代码,只有诱导性的病毒文件。当天,他们成为了 GitHub 上 star 增速最快的仓库。超过 180 个虚假僵尸账户正在传播病毒,等待不…...

CVE-2020-0796永恒之蓝2.0(漏洞复现)
目录 前言 产生原因 影响范围 漏洞复现 复现环境 复现步骤 防御措施 总结 前言 在网络安全的战场上,漏洞一直是攻防双方关注的焦点。CVE-2020-0796,这个被称为 “永恒之蓝 2.0” 的漏洞,一度引起了广泛的关注与担忧。它究竟是怎样的…...

游戏策划的分类
P3游戏策划分类 1.程序2.美术3.策划 程序:一般分为客户端程序和服务器程序 客户端程序一般负责游戏的前端画面表现 服务器程序负责游戏的后端运算 美术:角色原画,角色模型动作,场景原画,场景模型,UI设计&a…...

单片机基础模块学习——PCF8591芯片
一、A/D、D/A模块 A——Analog 模拟信号:连续变化的信号(很多传感器原始输出的信号都为此类信号)D——Digital 数字信号:只有高电平和低电平两种变化(单片机芯片、微控制芯片所能处理的都是数字信号) 下面…...

深入探索 HTML5 拖拽效果 API:打造流畅交互体验
在现代的 Web 开发中,交互性和用户体验一直是开发者关注的重点。HTML5 的拖拽效果 API (Drag and Drop API) 提供了一种非常直观的方式来让网页元素或文件能够被拖动并放置到页面的指定位置,极大提升了用户的交互体验。本篇文章将深入探讨如何使用 HTML5…...

【Healpix】python一种用于将球面划分为均匀区域的技术
Healpix 1、简介2、Healpix的基本原理3、Healpix的优点4、安装及使用4.1 安装healpy4.2 创建Healpix地图4.3 读取和写入Healpix数据4.4 数据插值 5、案例5.1 案例一:宇宙微波背景辐射(CMB)分析5.2 案例二:星系分布分析5.3 案例三&…...

Go:基于Go实现一个压测工具
文章目录 写在前面整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理 客户端模块Http客户端处理Grpc客户端处理Websocket客户端处理 连接处理模块GrpcHttp 统计数据模块统计原理实现过程 写在前面 本篇主要是基于Go来实现一个压测的工具,关于压测的内…...

算法-加油站问题
hello 大家好!今天开写一个新章节,每一天一道算法题。让我们一起来学习算法思维吧! function canCompleteCircuit(gas, cost) {// 加油站的总数const n gas.length;// 记录总剩余油量,若总剩余油量小于 0,说明无法绕环…...

UART ,IIC 和SPI三种总线协议
1.UART 1.1 简介 UART(Universal Asynchronous Receiver/Transmitter)即通用异步收发器。 常见的串行、异步通信总线,两条数据线Tx、Rx,实现全双工通信,常用于主机与外设的通信,点对点。 1.2 硬件连接 交叉…...

Padas进行MongoDB数据库CRUD
在数据处理的领域,MongoDB作为一款NoSQL数据库,以其灵活的文档存储结构和高扩展性广泛应用于大规模数据处理场景。Pandas作为Python的核心数据处理库,能够高效处理结构化数据。在MongoDB中,数据以JSON格式存储,这与Pandas的DataFrame结构可以很方便地互相转换。通过这篇教…...

动手学图神经网络(6):利用图神经网络进行点云分类
利用图神经网络进行点云分类 引言 在本教程中,大家将学习使用图神经网络(Graph Neural Networks, GNN)进行点云分类的基本工具。给定一组对象或点集的数据集,将这些对象嵌入到一个特征空间中,使得它们在特定任务下能够分类。将原始点云作为神经网络的输入,让网络学习捕…...

C语言从入门到进阶
视频:https://www.bilibili.com/video/BV1Vm4y1r7jY?spm_id_from333.788.player.switch&vd_sourcec988f28ad9af37435316731758625407&p23 //枚举常量 enum Sex{MALE,FEMALE,SECRET };printf("%d\n", MALE);//0 printf("%d\n", FEMALE…...

Python中容器类型的数据(下)
集合 集合 (set) 是一种可迭代的、无序的、不能包含重复元素的容器类型的数据。 Python中的集合是一种重要的数据结构,以下为你详细介绍: 定义与特点 无序性:集合中的元素没有固定顺序, {1, 2, 3} 和 {3, 2, 1} 在Python中是同一…...

MySQL 用户相关的操作详解
MySQL 5.x 用户操作 创建用户 在 MySQL 5.x 中,使用 GRANT 语句创建用户并授权: 语法 GRANT ALL PRIVILEGES ON *.* TO usernamehost IDENTIFIED BY password;username:用户名 host:指定用户可访问的主机,例如 loca…...

如何删除hugging face dowloaded的llm model?
如何删除hugging face dowloaded的llm model? 在现在需要使用llm进行research的情况下,经常会出现,由于下载模型太多,导致内存问题,然后需要删除某些不用的模型的情况,那么如何找到hugging face的模型保存…...

Vue 封装http 请求
封装message 提示 Message.js import { ElMessage } from "element-plus";const showMessage (msg,callback,type)>{ElMessage({message: msg,type: type,duration: 3000,onClose:()>{if (callback) {callback();}}}); }const message {error: (msg,…...

恒源云云GPU服务器训练模型指南
1数据上传 为了更方便的上传数据与下载数据,本例程采用xftp来完成数据的传输与下载。 XFTP下载链接,选择学生免费试用即可 2服务器的选择以及开启: 控制台->我的实例->点击创建实例 一般选择按量付费 接下来根据自己代码的torch版本…...

Spring Boot应用中实现基于JWT的登录拦截器,以保证未登录用户无法访问指定的页面
目录 一、配置拦截器进行登录校验 1. 在config层设置拦截器 2. 实现LoginInterceptor拦截器 3. 创建JWT工具类 4. 在登录时创建JWT并存入Cookie 二、配置JWT依赖和环境 1. 添加JWT依赖 2. 配置JWT环境 本篇博客将为大家介绍了如何在Spring Boot应用中实现基于JWT的登录…...

MySQL 基础学习(1):数据类型与操作数据库和数据表
MySQL 基础学习:数据类型与操作数据库和数据表 在这篇博客中,我们将深入学习 MySQL 的基础操作,重点关注数据库和数据表的操作,以及 MySQL 中常见的数据类型。希望本文能帮助你更好地理解和掌握 MySQL 的基本用法。 一、操作数据…...

zyNo.19
哈希(md5)绕过问题 本质上是弱类型问题的延申 题型 登录的哈希验证 $a ! $b Md5($a) md5($b) 解决办法Md5绕过 var_dump ("0e123456" "0e4456789"); //true 0e545993274517709034328855841020//true 参考资料0e开头的哈希…...

Kafka生产者ACK参数与同步复制
目录 生产者的ACK参数 ack等于0 ack等于1(默认) ack等于-1或all Kafka的同步复制 使用误区 生产者的ACK参数 Kafka的ack机制可以保证生产者发送的消息被broker接收成功。 Kafka producer有三种ack机制 ,分别是 0,1…...

IPhone14 Pro 设备详情
目录 产品宣传图内部图——后设备详细信息 产品宣传图 内部图——后 设备详细信息 信息收集于HubWeb.cn...

【Linux】磁盘
没有被打开的文件 文件在磁盘中的存储 认识磁盘 磁盘的存储构成 磁盘的效率 与磁头运动频率有关。 磁盘的逻辑结构 把一面展开成线性。 通过扇区的下标编号可以推算出在磁盘的位置。 磁盘的寄存器 控制寄存器:负责告诉磁盘是读还是写。 数据寄存器:给…...