MVC遇上bootstrap后的ajax表单验证

这篇文章主要为大家详细介绍了mvc遇上bootstrap后的ajax表单验证,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

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

@model object

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

    @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" })  

登录后复制

这样子以后在使用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中即可添加:

    

            

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

    

登录后复制

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

//ready      var $puserform = $("#puserform");      $puserform.dialog({        title: '新建用户',//.....      });      $("#btnCreateUser").click(function () {        var nodes = zTreeObjleft.getSelectedNodes();        if (nodes.length > 0) {          CreateUserForm($puserform);        }      })  function CreateUserForm(form) {      var $puserform = form;      $.ajax({        url: "CreateUser",        success: function (html) {          CreateUserFormSuccessCallback(html, $puserform);        }      });    }     function InitSelectDepartmentWhenCreateUser() {      $("#btnSelectDepartment").departmentSelection({        onSelected: function (name, id) {          $("#deptname").text(name);          $("#DepartmentId").val(id);        }      });    }     function CreateUserFormSuccessCallback(html, form) {      var $puserform = form;      $puserform.children().children().html(html);      $("#puserform").dialog("open");      var $form = $puserform.find("form")      InitSelectDepartmentWhenCreateUser();      $form.submit(function () {        $form.ajaxSubmit(function (data) {          if (data == "success") {            $("#puserform").dialog("close");            $("#puserform").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表单验证

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

AJAX请求队列实现

AJAX请求队列实现

AJAX请求队列实现

以上就是MVC遇上bootstrap后的ajax表单验证的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2759096.html

(0)
上一篇 2025年3月8日 08:23:03
下一篇 2025年2月27日 06:40:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Ajax 通过城市名获取数据

    本文给大家分享全国天气预报api ajax 通过城市名获取数据,通过html和js两部分代码实现天气预报效果,输入城市就会出现天气情况,效果非常棒,感兴趣的朋友可以参考下 预览图(比较简单粗糙) 聚合数据全国天气预报接口:https://w…

    2025年3月8日
    200
  • 通过数据库和ajax方法写出地图的实例代码

    ajax 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。这篇文章主要介绍了通过数据库和ajax方法写出地图的实例代码的相关资料,需要的朋友可以参考下 ajax教程 AJAX = Asynchronous JavaSc…

    2025年3月8日
    200
  • 聊聊Ajax提交form表单的看法和认识

    ajax,异步请求,通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新。通过本文给大家聊一聊ajax提交form表单的看法和认识,感兴趣的朋友一起学习吧 ajax (ajax开发) AJAX即“Asynchronous J…

    编程技术 2025年3月8日
    200
  • 使用原生ajax处理json字符串的方法

    json的全称是 javascript object notation(javascript对象表示法),是基于javascript对象字面量。这篇文章主要介绍了使用原生ajax处理json字符串的相关资料,需要的朋友可以参考下 AJAX …

    2025年3月8日
    200
  • jQuery中ajax的4种常用请求方式介绍

    ajax 是一种与服务器交换数据的技术,本文给大家分享四种ajax常用的请求方式,感兴趣的朋友一起看看吧 AJAX 是一种与服务器交换数据的技术,可以在补充在整个页面的情况下更新网页的一部分。 jQuery中ajax的4种常用请求方式: 1…

    编程技术 2025年3月8日
    200
  • ajax返回object Object的快速解决方法

    下面我就为大家带来一篇ajax返回object object的快速解决方法。现在就分享给大家,也给大家做个参考。 现象:使用ajax发送请求,因为后台PHP,使用了阿里的短信,后来返回类型object Object,在浏览器上看到是这样的返…

    编程技术 2025年3月8日
    200
  • Ajax中的循环方案

    在开发中,当一个列表页面加载完成后,我需要根据列表每一项的id去服务器端获取对应的数据然后再把获取的数据赋给当前id对应的标签,怎么实现的呢?下面我给大家介绍下ajax中的循环方案,感兴趣的朋友一起学习吧 Ajax 简介 Ajax 由 HT…

    2025年3月8日
    200
  • 用AJAX实现页面登陆以及注册用户名验证的简单实例

    下面我就为大家带来一篇用ajax实现页面登陆以及注册用户名验证的简单实例。现在就分享给大家,也给大家做个参考。 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交…

    编程技术 2025年3月8日
    200
  • 浅谈Bootstrap的DatePicker日期范围选择

    下面我就为大家带来一篇浅谈bootstrap的datepicker日期范围选择。现在就分享给大家,也给大家做个参考。 用日期插件时,经常会有一种需求。两个input框选择。开始时间小于结束时间,结束时间大于开始时间,开始时间和结束时间都不大…

    编程技术 2025年3月8日
    200
  • 基于ajax html实现文件上传技巧总结

    这篇文章主要为大家详细总结了基于ajax html实现文件上传技巧,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 引语:大家都知道,html中上传文件就一个input,type=file就搞定了。但是,这个标签的样式,实在不值得提点什么…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论