• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MVC遇上bootstrap后的ajax表单验证

    使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jquery.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);
     
    

    大致效果:

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • Bootstrap Validator 表单验证
    • Bootstrap中的表单验证插件bootstrapValidator使用方法整理(推荐)
    • 基于Bootstrap+jQuery.validate实现表单验证
    • 实用又漂亮的BootstrapValidator表单验证插件
    • JS组件Form表单验证神器BootstrapValidator
    • 基于Bootstrap+jQuery.validate实现Form表单验证
    • Ajax注册用户时实现表单验证
    • 自己编写的支持Ajax验证的JS表单验证插件
    • ajax jquery 异步表单验证示例代码
    • 基于PHP+Ajax实现表单验证的详解
    上一篇:Ajax与用户交互的JSON数据存储格式
    下一篇:Ajax通过XML异步提交的方法实现从数据库获取省份和城市信息实现二级联动(xml方法)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MVC遇上bootstrap后的ajax表单验证 MVC,遇上,bootstrap,后的,ajax,