<configuration> <appSettings><add key="ClientValidationEnabled" value="true" /><add key="UnobtrusiveJavaScriptEnabled" value="true" /> </appSettings></configuration>我们还是之前的项目:
using System;using System.Collections.Generic;using System.ComponentModel.DataAnnotations;using System.Linq;using System.Web;namespace Server_Side_Validation_IN_MVC.Models{public class StudentServer{[Required(ErrorMessage="Name为必填项")]public string Name { get; set; }[Required(ErrorMessage="电子邮件必须")][EmailAddress(ErrorMessage="电子邮件格式不对")]public string Email { get; set; }}}
public ActionResult SeverSideIndex(){return View();}[HttpPost]public ActionResult SeverSideIndex(StudentServer model){if (ModelState.IsValid){ViewBag.Name = model.Name;ViewBag.Email = model.Email;}return View();}不同的是,这里,我添加视图,不一样:
注意这里一定要勾选引用脚本库,也就是引入Jquery和Jquery插件,这样才能进行客户端验证:
修改一下默认路由:
public static void RegisterRoutes(RouteCollection routes){routes.IgnoreRoute("{resource}.axd/{*pathInfo}");routes.MapRoute(name: "Default",url: "{controller}/{action}/{id}",defaults: new { controller = "Student", action = "SeverSideIndex", id = UrlParameter.Optional });}运行项目:
我们在控制器的POST方法中添加一个断点
直接点击按钮:没有调用POST方法,直接在客户端验证了数据的合法性。
输入合法的数据:
断点触发了,也就是说,在客户端验证通过之后,才会提交到服务器进行进一步处理。
好了,这就是客户端验证,比较简单。但注意要引入Jquery插件
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。