国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > AJAX > 正文

MVC遇上bootstrap后的ajax表單驗證

2024-09-01 08:27:38
字體:
來源:轉載
供稿:網友

使用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();      });    }            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿合奇县| 屏山县| 尖扎县| 蒙自县| 堆龙德庆县| 当阳市| 大安市| 田阳县| 自治县| 闽侯县| 巴彦县| 繁峙县| 漳平市| 兴化市| 定州市| 武功县| 奉化市| 昭平县| 南陵县| 罗甸县| 牡丹江市| 保山市| 敖汉旗| 会东县| 蚌埠市| 余姚市| 穆棱市| 舟山市| 四子王旗| 四川省| 东明县| 额尔古纳市| 阿合奇县| 麻栗坡县| 济阳县| 无极县| 陵川县| 肇源县| 陵川县| 长春市| 宕昌县|