使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jqueyr.validate的话只有使用他自己的样式了,而且有模型在使用模型验证更方便点。怎么解决呢?

当然你可以专门写一个针对此的jquery插件,我觉得蛮麻烦的,喜欢写插件的研究下吧。

首先Nuget获取一个 MVC EditorTemplates for Bootstrap 3 的组件,有了他以后就有了一些模版,比如比较简单的一个Text:

@model object

<div class="form-group@(Html.ValidationErrorFor(m => m, " has-error"))">

@Html.LabelFor(m => m, new { @class = "control-label" })

<div class="controls">

@Html.TextBox(

"",

ViewData.TemplateInfo.FormattedModelValue,

ViewBag.ClearTextField == true ? new { @class = "form-control clear-text-field input-block-level" } : new { @class = "form-control input-block-level" } )

@Html.ValidationMessageFor(m => m, null, new { @class = "help-block" })

</div>

</div>

这样子以后在使用EditorFor后就会直接输出bootstrap需要的html,比较方便。

我们看到里面已经有了验证失败的has-error的处理,第二个问题来了,我们需要前端验证,ajax验证也行啊,还有自定义验证呢?

于是乎继续利用MVC自带的模型验证,刚才获取的组件中有个Validation类,我们先在里面添加一个扩展方法用于非强类型

public static MvcHtmlString ValidationError(this HtmlHelper htmlHelper, string field, string error)

{

if (HasError(htmlHelper, ModelMetadata.FromStringExpression(field, htmlHelper.ViewData), field))

return new MvcHtmlString(error);

else

return null;

}

View中即可添加:

<div class="form-group@(Html.ValidationError("Department", " has-error"))">

<label class="control-label" for="DepartmentId">所在部门</label>

<div class="controls">

<span id="deptname"> </span><a id="btnSelectDepartment">选择部门</a>

<input class="form-control" data-val="true" data-val-required="部门是必需的。" id="DepartmentId" name="DepartmentId" type="hidden" value="">

@Html.ValidationMessage("Department", null, new { @class = "help-block" })

</div>

</div>

最后在脚本中处理ajax提交和回发的处理,不知道用MVC的Ajax.BeginForm能不能更方便点,不过个人觉得这东西不是很灵活,所以继续用ajaxSubmit及jquery.ajax:

//ready

var $divuserform = $("#divuserform");

$divuserform.dialog({

title: '新建用户',//.....

});

$("#btnCreateUser").click(function () {

var nodes = zTreeObjleft.getSelectedNodes();

if (nodes.length > 0) {

CreateUserForm($divuserform);

}

})

function CreateUserForm(form) {

var $divuserform = form;

$.ajax({

url: "CreateUser",

success: function (html) {

CreateUserFormSuccessCallback(html, $divuserform);

}

});

}

function InitSelectDepartmentWhenCreateUser() {

$("#btnSelectDepartment").departmentSelection({

onSelected: function (name, id) {

$("#deptname").text(name);

$("#DepartmentId").val(id);

}

});

}

function CreateUserFormSuccessCallback(html, form) {

var $divuserform = form;

$divuserform.children().children().html(html);

$("#divuserform").dialog("open");

var $form = $divuserform.find("form")

InitSelectDepartmentWhenCreateUser();

$form.submit(function () {

$form.ajaxSubmit(function (data) {

if (data == "success") {

$("#divuserform").dialog("close");

$("#divuserform").clearForm();

}

else {

CreateUserFormSuccessCallback(data, form);

}

});

event.preventDefault();

});

}

后台Action方法中我们便可为其补充自定义验证:

if (!DepartmentId.HasValue)

{

ModelState.AddModelError("Department", "必须选择部门");

}

if (ModelState.IsValid)

{

user.Id = Guid.NewGuid();

user.CreateTime = DateTime.Now;

if (DepartmentId.HasValue)

{

var dept = new DeptUserRole();

dept.DepartmentId = DepartmentId.Value;

dept.IsMain = true;

dept.RoleId = RoleId.Value;

user.DeptUserRoles.Add(dept);

}

db.Users.Add(user);

await db.SaveChangesAsync();

return Content("success");

}

return View(user);

大致效果:

转:MVC遇上bootstrap后的ajax表单验证的更多相关文章

  1. MVC遇上bootstrap后的ajax表单模型验证

    MVC遇上bootstrap后的ajax表单验证 使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jqueyr.validate的话只有使用他自己的样式了, ...

  2. jquery php ajax 表单验证

    本实例用到 JQuery 类库本身的函数和功能,所有表单信息利用 PHPMailer 类库邮件的形式发送.   .创建一个表单 html 页面   表单部分 html 代码   以下为引用内容: &l ...

  3. 基于Bootstrap+jQuery.validate Form表单验证实践

    基于Bootstrap jQuery.validate Form表单验证实践 项目结构 :     github 上源码地址:https://github.com/starzou/front-end- ...

  4. Spring MVC 文件上传、Restful、表单校验框架

    目录 文件上传 Restful Restful 简介 Rest 行为常用约定方式 Restful开发入门 表单校验框架 表单校验框架介绍 快速入门 多规则校验 嵌套校验 分组校验 综合案例 实用校验范 ...

  5. validate+jquery+ajax表单验证

    1.案例 1.1 Html form表单内容 <form class="cForm" id="cForm" method="post" ...

  6. Ajax 表单验证 实现代码

    兼容: opera 9.6 + chrome 2.0 + FF 3 + IE 6 效果:一边输入一边实现验证 image 环境:ruby 1.8.6 + rails 2.1.0 + windows 核 ...

  7. ajax+表单验证+验证码生成例子

    MainController.class.php <?php namespace AjaxYz\Controller; use Think\Controller; class MainContr ...

  8. jQuery Validatede 结合Ajax 表单验证提交

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. boostrap ajax表单验证提交

    =============================================================================== 1. 1 <link href=& ...

随机推荐

  1. 组件(Conponent)是图形用户界面最基本的部分

    组件(Conponent)是图形用户界面最基本的部分,也称为构件 ,是可以以图形化的方式显示在屏幕上,并能与用户进行交互的对象,例如一个按钮,一个标签等. 组件不能独立地显示出来,必须将其放在一定的容 ...

  2. CocosCreate 与 Netty 开发斗地主 (一步一步开发)

    CocosCreate 与  Netty 开发斗地主 开发此教程的目的是为了教会大家基本的使用Netty,通过一个小例子来教会大家制作斗地主游戏服务器,采用WebSocket方式! 目前正在制作阶段, ...

  3. AutoMapper整理收集

    http://www.cnblogs.com/jobs2/p/3503990.html http://www.cnblogs.com/1-2-3/p/AutoMapper-Best-Practice. ...

  4. 【BZOJ4382】[POI2015]Podział naszyjnika 堆+并查集+树状数组

    [BZOJ4382][POI2015]Podział naszyjnika Description 长度为n的一串项链,每颗珠子是k种颜色之一. 第i颗与第i-1,i+1颗珠子相邻,第n颗与第1颗也相 ...

  5. Python之实现简单计算器功能

    一,需求分析 要求计算一串包含数字+-*/()的类似于3*( 4+ 50 )-(( 100 + 40 )*5/2- 3*2* 2/4+9)*((( 3 + 4)-4)-4)表达式的数值 二,知识点 正 ...

  6. Net应用架构设计

    N-Tier 是从架构更大的维度上划分,每一个维度都是一个Tier(在微软的ESP2.0里翻译为”级”),比如电商架构划分如下: UI 服务接口 消息.缓存中间件 数据库 ...... Tier与Ti ...

  7. ASP.Net请求处理机制初步探索之旅 - Part 2 核心(转)

    开篇:上一篇我们了解了一个请求从客户端发出到服务端接收并转到ASP.Net处理入口的过程,这篇我们开始探索ASP.Net的核心处理部分,借助强大的反编译工具,我们会看到几个熟悉又陌生的名词(类):Ht ...

  8. Outlook Top of Information Store

    Actually I got to thinking this might make a good blog post so I took a closer look - Try this: On t ...

  9. Java 语言基础之函数

    函数的定义: 函数就是定义在类中的具有特定功能的一段独立小程序 函数也称为方法 函数定义格式: 修饰符 返回值类型 函数名(参数类型 形式参数1, 参数类型 形式参数2,...) { 执行语句; re ...

  10. 6.Insert Documents-官方文档摘录

    总结 1.插入单文档 db.inventory.insertOne( { item: "canvas", qty: , tags: , w: 35.5, uom: "cm ...