- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
情况是,Student Reg 的组合。否。 并且选择类(class) 始终是独一无二的。
在选择之前保存在数据库中的组合后,预期的结果是,
第一个预期结果:
将出现“所选学生已参加此类(class)”的错误消息。
第二个预期结果:
它将阻止提交表单,直到选择了之前未保存在数据库中的不同组合。
当前结果:
第一个预期结果运行良好:
但是,第二个预期结果不起作用。即提交表单并保存之前已经保存在数据库中的组合。
能否请您给出解决方案,因为我可以得到第二个预期结果?
提前致谢。
为了便于阅读,我排除了所有与姓名、电子邮件和部门相关的代码、html 和脚本。
这是我的模型,
using System;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Web.Mvc;
namespace UniversityApplication.Models
{
public class CourseStudent
{
[Required]
[DisplayName("Student Reg. No.")]
public string CourseStudentRegNo { get; set; }
[Required]
[Remote("IsCourseNameExists", "CourseStudents", AdditionalFields = "CourseStudentRegNo", ErrorMessage = "Selected Student has taken this course already.")]
[DisplayName("Select Course")]
public string CourseStudentCourse { get; set; }
[Required]
[DisplayName("Date")]
[DataType(DataType.Date)]
public DateTime CourseStudentRegDate { get; set; }
}
}
这是我的 Controller ,
using System.Collections.Generic;
using System.Linq;
using System.Web.Mvc;
using UniversityApplication.Context;
using UniversityApplication.Models;
namespace UniversityApplication.Controllers
{
public class CourseStudentsController : Controller
{
private ApplicationContext db = new ApplicationContext();
public ActionResult StudentToCourse()
{
GenerateDropDownValue();
return View();
}
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult StudentToCourse([Bind(Include = "CourseStudentID,CourseStudentRegNo,CourseStudentName,CourseStudentEmail,CourseStudentDepartmentCode,CourseStudentCourse,CourseStudentRegDate")] CourseStudent courseStudent)
{
GenerateDropDownValue();
if (ModelState.IsValid)
{
db.CoursesStudents.Add(courseStudent);
db.SaveChanges();
ModelState.Clear();
return View();
}
ModelState.Clear();
return View();
}
private void GenerateDropDownValue()
{
List<Student> allRegisteredStudents = new List<Student>();
List<SelectListItem> students = new List<SelectListItem>();
List<Course> allCourses = new List<Course>();
string studentName = "";
string studentEmail = "";
string studentDepartment = "";
using (ApplicationContext db = new ApplicationContext())
{
allRegisteredStudents = db.Students.OrderBy(a => a.StudentRegNo).ToList();
}
foreach (var student in allRegisteredStudents)
{
students.Add(
new SelectListItem()
{
Value = student.StudentRegNo,
Text = student.StudentRegNo
}
);
}
ViewBag.Students = students;
ViewBag.CourseCode = new SelectList(allCourses, "CourseCode", "CourseName");
ViewBag.StudentName = studentName;
ViewBag.StudentEmail = studentEmail;
ViewBag.StudentDepartment = studentDepartment;
}
public JsonResult IsCourseNameExists(string CourseStudentCourse, string CourseStudentRegNo)
{
return Json(!db.CoursesStudents.Any(x => x.CourseStudentCourse == CourseStudentCourse && x.CourseStudentRegNo == CourseStudentRegNo), JsonRequestBehavior.AllowGet);
}
protected override void Dispose(bool disposing)
{
if (disposing)
{
db.Dispose();
}
base.Dispose(disposing);
}
}
这是我的观点,
@model UniversityApplication.Models.CourseStudent
@{
ViewBag.Title = "Create";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Create</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<h4>CourseStudent</h4>
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group">
@Html.LabelFor(model => model.CourseStudentRegNo, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CourseStudentRegNo, @ViewBag.Students as SelectList, "Select Student", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CourseStudentRegNo, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CourseStudentCourse, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CourseStudentCourse, @ViewBag.CourseCode as SelectList, "Select Course", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CourseStudentCourse, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CourseStudentRegDate, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.CourseStudentRegDate, new { @class = "date form-control", @readonly = "true" })
@Html.ValidationMessageFor(model => model.CourseStudentRegDate, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Enroll" class="btn btn-default" />
</div>
</div>
</div>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
<link href="~/Content/themes/base/all.css" rel="stylesheet" />
@section Scripts {
<script src="~/Scripts/jquery.validate.date.js"></script>
@Scripts.Render("~/bundles/jqueryui")
@Styles.Render("~/Content/cssjqryUi")
@Scripts.Render("~/bundles/jqueryval")
<script>
$(document).ready(function () {
$('.date').datepicker({ dateFormat: "dd/mm/yy" });
});
</script>
}
最佳答案
与其通过 JsonResult 方法 IsCourseNameExists
使用自定义远程验证,不如通过自定义数据注释 实现验证。
引用此链接了解如何通过数据注释创建自定义验证:Custom Validation Data Annotation Attribute
如果验证不成功则使用它,那么您将拥有无效的模型状态并且您无需担心该错误。它还使您的架构更加安全。
此外,作为最佳实践,您还应该在 Controller 的服务器端进行相同的检查(您在 IsCourseNameExists
方法中进行的检查),就在之前您正在保存到数据库。 注意:如果您只执行此检查,即使您的要求得到满足。
关于c# - 远程验证显示错误消息但仍让表单提交并保存在数据库 MVC 5,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36997402/
我在 mongodb 中的玩家和锦标赛之间存在多对多关系。 我希望能够一次将许多玩家添加到锦标赛中。如果没有 ajax,这很简单,但我们有一个包含数千名玩家的数据库,因此表单选择变得巨大。 我们想为此
这个问题已经有答案了: When should I use html's and when spring's in Spring MVC web app? (3 个回答) 已关闭 6 年前。 我正
我正在 C++ Builder XE4 上使用 VCL。 我有以下组件。 FormMain 具有 TButton *B_select; FormSelect(或DialogSelect)具有 TCom
如何在不影响表单控件的情况下更改表单的 alphablend? 德尔福XE7 最佳答案 此问题的一个解决方案是使用多设备应用程序(如果无法使用VCL)。 如果您需要保留透明的TForm,只需更改属性T
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在尝试扩展 Django 注册以包含我自己的注册表单。原则上这是相当简单的。我只需要编写自己的表单( CustomRegistrationForm ),它是原始表单( RegistrationFo
我正在尝试为我的网站实现聊天功能。为了做到这一点,我遵循了以下教程:https://channels.readthedocs.io/en/latest/tutorial/ 然后我稍微更改了代码以实现它
有一个问题,我需要用一个 html 表单提交两个相互关联的模型表单。我知道如何提交两个单独的表格,但是在相关模型表格的情况下外键让我发疯。 问题是,第二个表单应该用外键填充字段到第一个表单的实例。 在
我正在创建一个工具,允许某人输入食谱,然后将其保存为 XML 文件,我已经创建了 XSD,但我想知道如何在我的网页上制作一个表单以允许用户输入他们的食谱并遵守模式。我一直在研究 Ajax 和 Jque
在 .net win 表单(如 asp.net web 表单)中是否有可用的验证控件? 因为很难为我的每个控件设置正确的条件,所以我的表单中也有很多重复的代码。 正确的做法是什么? 最佳答案 看看这个
我有一个简短的问题。我正在学习如何使用 javascript 制作注册表,发现此链接非常有用。 http://www.w3resource.com/javascript/form/javascript
我正在开发一个项目,该项目将使用循环将许多表单添加到 mysql 数据库中。在 javascript 部分中,我无法让 var i 在函数 updatesum() 中工作。有人可以帮我吗? 我试图避免
在我的应用程序上有一个包含 2 个字段和一个保存按钮的表单。 在我的 onClick 结束时我需要什么来将光标返回到第一个字段。 我有这个来清除它们 txtData.setText("
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
<input type="text" name="textfield" onKeyPress="javascript:alert(event.
我正在构建的网站有一个登录表单,作为所有其他模板扩展的 base.html 模板的一部分;因此,我需要以某种方式处理每个页面上的登录/注销逻辑。 目前每个页面都在单独的 View 中加载,那么实现它的
我有一个表单类,看起来像.. #forms.py class ExampleForm(forms.Form): color = forms.CharField(max_length=25)
有没有办法在表单定义中给表单一个特殊的错误渲染函数?在 customizing-the-error-list-format 下的文档中它展示了如何为表单提供特殊的错误呈现函数,但似乎您必须在实例化表单
我正在处理由多个页面组成的表单,我想解决验证问题。 当我点击提交按钮时,当前页面上的所有字段都会在下方显示错误消息,但是如果我更改页面,那么我需要再次点击提交,因为这些字段未设置为已触摸。 如果我可以
是否可以附加到继承表单的 exclude 或 widgets 变量? 到目前为止,我有以下设置。 class AddPropertyForm(forms.ModelForm): num_mon
我是一名优秀的程序员,十分优秀!