前言:

在本篇 Taurus.MVC WebMVC 入门开发教程的第五篇文章中,我们将学习如何处理表单提交和进行数据验证。

这是 Web 开发中非常重要的一部分,因为它涉及到用户输入数据的处理和有效性验证。

我们将继续使用 Taurus.Mvc 命名空间,并探讨如何在控制器中接收表单数据、进行数据验证并给出相应的响应。

步骤1:创建视图

首先,我们需要创建一个包含表单的视图。

在视图文件(例如 create.html)中,我们可以使用 HTML 表单元素来接收用户输入的数据。

<!DOCTYPE html>
<html>
<head>
<title>创建用户</title>
</head>
<body>
<h1>创建用户</h1>
<form method="post">
<label for="name">姓名:</label>
<input type="text" name="name" id="name" required>
<br>
<label for="age">年龄:</label>
<input type="number" name="age" id="age" required>
<br>
<input type="submit" value="提交" name="btnAddUser">
<div id="printMsg"></div>
</form>
</body>
</html>

在上述代码中,我们创建了一个简单的表单,包含一个文本输入框和一个数字输入框,用于接收用户的姓名和年龄。

表单的 method 属性被设置为 post,默认将数据提交到当前页面。

同时给按钮起了个名称"btnAddUser",事件按钮,对应控制器的方法。

步骤2:更新控制器

接下来,我们需要在控制器中创建一个方法来处理表单提交。

我们继续沿用上文使用到的 HomeController.cs 文件,并在其中添加一个名为 Create 的方法,用来呈现显示页面内容。

同时添加 BtnAddUser 方法【和按钮同名,不区分大小写】来处理按钮事件。

public class HomeController : Taurus.Mvc.Controller
{
public void Index()
{
...
} public void Create() { } public void BtnAddUser(string name, int age)
{
View.Set("printMsg", name + " - " + age);
}
}

在 HomeController 类中,定义和 Create.html 同名的方法,用来显示该表单界面。

同时添加 BtnAddUser 方法,来处理按钮点击事件。

上述代码中的 BtnAddUser 方法可以指定接收 表单 对象作为参数,其中包含了表单提交的数据。

我们也可以通过 Query<string>("name") 和 Query<int>("age") 来获取相应的用户输入值。

上述示例代码中,最后通过:View.Set 方法,可以将数据呈现在指定(ID=“printMsg”)的 Html 标签中。

步骤3:进行数据验证

在表单提交后,我们通常需要对用户输入的数据进行验证,以确保其有效性。

在上述代码的中,我们将参数表单的接收参数,定义到方法参数中,同时指定了数据类型。

对于表单参数较少时:

将表单参数放到方法参数中,可以简化代码,同时利用框架的的数据类型转换,进行有效转换。

对于参数较多时:

您可以通过定义实体Model,并将它定义到方法参数中,例如:

    public void BtnAddUser(User user)
{
View.Set("printMsg", user.name + " - " + user.age);
}

当然我们也可以不定义任何方法参数,通过 Query<T>(Name) 方法来获取相应的用户输入值。

    public void BtnAddUser()
{
View.Set("printMsg", Query<String>("name") + " - " + Query<int>("age"));
}

接下来,您需要自行添加数据验证的逻辑,以保证程序的稳定输出。

例如,您可以使用条件语句、正则表达式或其他验证方式来检查用户输入的数据是否符合要求。

如果数据验证失败,您可以返回一个视图,向用户显示错误信息并要求重新输入。

如果数据验证成功,您可以执行其他操作(例如保存到数据库)并重定向用户到另一个页面。

步骤4:运行应用程序

最后,运行应用程序并访问 /Home/Create 路由,您将看到一个表单页面。

尝试提交表单并查看控制台输出,您将看到用户输入的姓名和年龄被成功获取。

总结

通过本篇教程,我们学习了如何在 Taurus.MVC WebMVC 中处理表单提交和进行数据验证。

我们创建了一个包含表单的视图,并在控制器中接收表单数据,并进行数据验证和其他逻辑操作。

本系列的目录大纲为:

Taurus.MVC WebMVC 入门开发教程1:框架下载环境配置与运行

Taurus.MVC WebMVC 入门开发教程2:一个简单的页面呈现

Taurus.MVC WebMVC 入门开发教程3:数据绑定Model

Taurus.MVC WebMVC 入门开发教程4:数据列表绑定List<Model>

Taurus.MVC WebMVC 入门开发教程5:表单提交与数据验证

Taurus.MVC WebMVC 入门开发教程6:路由配置与路由映射

Taurus.MVC WebMVC 入门开发教程7:部分视图和页面片段

Taurus.MVC WebMVC 入门开发教程5:表单提交与数据验证的更多相关文章

  1. Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行(含系列目录)。

    前言: Taurus.MVC 微服务版本已经发布了:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单. 以前都是框架发布时写点相关功能点的文章,没有形成 ...

  2. Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  3. Taurus.MVC WebAPI 入门开发教程3:路由类型和路由映射。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  4. Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  5. Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  6. Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  7. Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  8. EasyUI中在表单提交之前进行验证

    使用EasyUi我们可以在客户端表单提交之前进行验证,过程如下:只需在onSubmit的时候使用return  $("#form1").form('validate')方法即可,E ...

  9. AngularJS 表单提交后显示验证信息与失焦后显示验证信息

    虽然说AngularJS的实时表单验证非常有用,非常高效方便,但是当用户还没有完成输入时便弹出一个错误提示,这种体验是非常糟糕的. 正常的表单验证逻辑应该是在用户提交表单后或完成当前字段中的输入后,再 ...

  10. Form表单提交,js验证

    Form表单提交,js验证 1,  Onclick() 2, Onsubmit() Button标签 input (属性 submit  button )标签 Input type=button    ...

随机推荐

  1. [转帖]LTP使用和分析

    一.安装及编译流程 1.下载LTP LTP 项目目前位于 GitHub,项目地址:https://github.com/linux-test-project/ltp . 获取最新版可以执行以下命令: ...

  2. PostgreSQL简单添加只读用户的方法

    1. 添加了白名单只读来避免开发同事错误的修改数据库内的数据, 但是他们总想去查询数据库的内容. 最简单的办法是修改pg_hba.conf添加只读用户. 2. 添加只读用户. 使用psql登录pg数据 ...

  3. 编译打包rabbitmq然后一键部署的简单方法

    摘要 之前总结过一版,但是感觉不太全面 想着本次能够将使用中遇到的问题总结一下. 所以本次是第二版 介质下载 rabbitmq 不区分介质的打包文件 rabbitmq-server-generic-u ...

  4. 使用rpmbuild打包erlang和rabbitmq进行部署服务的方法

    使用rpmbuild打包erlang和rabbitmq进行部署服务的方法 背景说明 1. rabbitmq 是基于 erlang 开发的消息列队, 本身rabbitmq 自己不区分架构. 2. 但是e ...

  5. 源码阅读:VictoriaMetrics中的golang代码优化方法

    全文请移步:https://zhuanlan.zhihu.com/p/469239020 或关注我的公众号: 公众号:一本正经的瞎扯

  6. Registration Authority 简介

    RA 功能简介 在公共密钥基础设施(PKI)中,CA(Certificate Authority,证书颁发机构)系统的RA(Registration Authority,注册机构)是PKI体系结构的重 ...

  7. 【云原生】为什么要虚拟化,为什么要容器,为什么要Docker,为什么要K8S?

    前言 如标题中的问题所提到的虚拟化,容器,Docker和K8s那样,我们不妨这样问:这些技术到底适用于哪些场景,有没有别的技术可以替代?这些技术的优劣在哪里? 下面我将针对性地从以上几个问题的出发点, ...

  8. 大语言模型的预训练[1]:基本概念原理、神经网络的语言模型、Transformer模型原理详解、Bert模型原理介绍

    大语言模型的预训练[1]:基本概念原理.神经网络的语言模型.Transformer模型原理详解.Bert模型原理介绍 1.大语言模型的预训练 1.LLM预训练的基本概念 预训练属于迁移学习的范畴.现有 ...

  9. C/C++ 实现常用的线程注入

    各种API远程线程注入的方法,分别是 远程线程注入,普通消息钩子注入,全局消息钩子注入,APC应用层异步注入,ZwCreateThreadEx强力注入,纯汇编实现的线程注入等. 简单编写DLL文件: ...

  10. blazor maui hybrid app显示本地图片

    啊... ... 一通操作下来感觉就是两个字 折磨 跨平台有跨平台的好处 但框架本身支持的有限 很多东西做起来很曲折 哎 这里总结一下笔者为了折腾本地图片显示的尝试 为什么要做本地图片展示呢 如果是做 ...