日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

ASP.NET MVC Unobtrusive JavaScript 实现 onfocusout 验证, onfocusin 清除错误

發布時間:2025/3/21 asp.net 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ASP.NET MVC Unobtrusive JavaScript 实现 onfocusout 验证, onfocusin 清除错误 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在 ASP.NET MVC 中啟用 Unobtrusive JavaScript 功能,可以在運行時由服務器端根據Model中設置的驗證規則,自動生成客戶端驗證js代碼(結合jquery.validate)。這很好地解決了表單驗證時一次代碼,兩次驗證(客戶端+服務器端)的問題。

使用它很簡單,主要操作步驟如下:

1. 在web.config增加如下設置:

<appSettings><add key="ClientValidationEnabled" value="true"/><add key="UnobtrusiveJavaScriptEnabled" value="true"/> </appSettings>

2. 在NuGet中引用jquery.validate與jquery.validate.unobtrusive

3. 在頁面中添加js引用:

<script type="text/javascript" src="/scripts/jquery.validate.min.js"></script> <script src="/scripts/jquery.validate.unobtrusive.min.js" type="text/javascript"></script>

4. 在model中添加驗證規則,示例代碼如下:

public class SignupUser {[Required(ErrorMessageResourceName = "DefaultRequireErrorMsg", ErrorMessageResourceType = typeof(Resources))][DataType(DataType.EmailAddress)]public string Email { get; set; } }

5. 在頁面中添加表單生成代碼,比如:

@using(Html.BeginForm()) { @Html.LabelFor(m=>m.Email)@Html.TextBoxFor(m=>m.Email)@Html.ValidationMessageFor(m=>m.Email) }

參考文章:Unobtrusive JavaScript in ASP.NET MVC 3

進入正題

默認情況下,jquery.validate.unobtrusive只在點擊表單提交按鈕時才觸發驗證,驗證出錯時,光標移入輸入框不會清除錯誤提示信息(jquery.validate也一樣,unobtrusive只是jquery.validate的一個擴展)。

而我們的需求是,只要光標移出輸入框(onfocusout)就觸發驗證,光標移入輸入框(onfocusin)時清除錯誤信息。

效果如下:

1.?光標移出(onfocusout)時

2.?光標移入(onfocusin)時

如何解決這個問題呢?

解決方法是簡單的,找到解決方法的過程是曲折的。

jquery.validate對這個需求并沒有提供很好的支持,需要研究它的代碼,接管onfocusout與onfocusin的事件處理,并屏蔽onkeyup的事件處理。最終解決問題的代碼如下:

針對jquery.validate.unobtrusive:

$.validator.setDefaults({//光標移出時onfocusout: function (element) {this.element(element);},//光標移入時onfocusin: function (element, event) {//找到顯示錯誤提示的標簽并移除,針對jquery.validate.unobtrusivevar errorElement = $(element).next('span.field-validation-error');if (errorElement) {errorElement.children().remove();}},onkeyup: function (element, event) {} });

如果沒有使用jquery.validate.unobtrusive,想在jquery.validate中實現同樣的效果,對應的代碼如下:

$.validator.setDefaults({//光標移出時onfocusout: function (element) {this.element(element);},//光標移入時onfocusin: function (element, event) {//僅針對jquery.validatevar errorElement = this.errorsFor(element);if (errorElement) {errorElement.remove();}},onkeyup: function (element, event) {} });

好了,這篇博文就是為了分享一下自己摸索出來的解決方法。

?

相關博問:ASP.NET MVC 表單驗證用什么好

總結

以上是生活随笔為你收集整理的ASP.NET MVC Unobtrusive JavaScript 实现 onfocusout 验证, onfocusin 清除错误的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。