改写jquery.validate.unobtrusive.js实现气泡提示mvc错误

个人对于这个js、css不是很擅长,所以这个气泡提醒的样式网上找了下,用了这个http://www.cnblogs.com/wifi/articles/2918950.html当中的第一种写法。

对于mvc中默认的错误提示,是使用@Html.ValidationMessageFor这个来生成个<span class="field-validation-valid" data-valmsg-for="XXX" data-valmsg-replace="true"></span>这种的html标签,但是对于span首先它得占页面的空间,而且我需要它里面有字的时候才显示,没字的时候就得隐藏,css不好弄,所以就得改这个jquery.validate.unobtrusive.js来实现。

(当然mvc中错误提示还有@Html.ValidationSummary,不过这个我发现它都是页面回发的时候才会变化的,所以我可以在页面load出来的时候就能够判断到里面有没有文字,然后再去控制如何显示出来,这个实现起来就比较简单,也不用去改动源码啥的,这里就不提了。)

我改的jquery.validate.unobtrusive.js中的onerror方法:

 1     function CPos(left, top) {
 2         this.left = left;
 3         this.top = top;
 4     }
 5 
 6     function GetObjPos(ATarget) {
 7         var target = ATarget;
 8         var pos = new CPos(target.offsetLeft, target.offsetTop);
 9 
10         var target = target.offsetParent;
11         while (target) {
12             pos.left += target.offsetLeft;
13             pos.top += target.offsetTop;
14 
15             target = target.offsetParent
16         }
17         return pos;
18     }
19 
20     function onError(error, inputElement) {  // 'this' is the form element
21         var container = $(this).find("[data-valmsg-for='" + inputElement[0].name + "']"),
22             replace = $.parseJSON(container.attr("data-valmsg-replace")) !== false;
23 
24         container.removeClass("field-validation-valid").addClass("field-validation-error");
25         error.data("unobtrusiveContainer", container);
26 
27         var pos = GetObjPos(inputElement[0]);
28         if (error.text().length > 0) {
29             if ($("[popupfor='" + inputElement[0].name + "']").length == 0) {
30                 $(document.body).append("<div class=\"poptip\" popupfor=\"" + inputElement[0].name + "\" style=\"top: " + (pos.top + inputElement.height()) + "px;left:" + pos.left + "px;\"><span class=\"poptip-arrow poptip-arrow-top\"><em>◆</em><i>◆</i></span>" + error.text() + "</div>");
31             }
32             else {
33                 $("[popupfor='" + inputElement[0].name + "']").contents().filter(function () {
34                     return this.nodeType == 3;
35                 }).replaceWith(error.text());
36             }
37             $("div[popupfor='" + inputElement[0].name + "']").show();
38         }
39         else {
40             $("div[popupfor='" + inputElement[0].name + "']").hide();
41         }
42 
43         if (replace) {
44             container.empty();
45             error.removeClass("input-validation-error").appendTo(container);
46         }
47         else {
48             error.hide();
49         }
50     }

 

红色的是我加的,代码比较简单。

然后cshtml中我使用了个隐藏的div,把这个@Html.ValidationMessageFor给包起来。

.hide {display:none;}

<div class="hide">@Html.ValidationMessageFor(model => model.XXX)</div>

效果图:

 

posted on 2013-09-09 11:26  张祈璟  阅读(8348)  评论(8编辑  收藏  举报