日韩性视频-久久久蜜桃-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 清除错误的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 草草影院1| 久久久视频在线 | av一级大片 | 九九午夜 | 成人免费在线观看av | 无套内谢的新婚少妇国语播放 | 超碰1000 | 青青国产在线视频 | 亚洲欧美色视频 | 中国性猛交| 久色网站| 欧美日韩va | 中文字幕在线观看网站 | 久草中文视频 | 大陆av片 | 成年人黄色免费网站 | 精品久久二区 | 老牛影视一区二区三区 | 成年人网站免费视频 | 91丝袜美女 | 欧美伦理片网站 | 99蜜桃臀久久久欧美精品网站 | 国产高清免费av | 99ri在线观看 | 免费的av网站 | av片在线播放| 日韩成人自拍 | 亚洲国产精品国自产拍久久 | 91视频入口 | 亚洲最大看欧美片网站 | 免费看aaaaa级少淫片 | 少妇高潮网站 | 欧美日韩电影一区 | 日韩黄色免费电影 | 97影视 | 蜜臀aⅴ国产精品久久久国产老师 | 久久99亚洲精品 | 亚洲综合涩 | 亚洲色图偷拍视频 | 97香蕉超级碰碰久久免费软件 | 亚洲成人久久精品 | 真实的国产乱xxxx在线91 | 日韩毛片在线播放 | 欧美人与动物xxxxx | 极品国产白皙 | 欧美另类自拍 | 欧美一区二区三区四 | 免费观看一区二区三区视频 | 欧美人与性动交ccoo | 欧美三级免费观看 | 日韩视频成人 | 国产精品自产拍 | 18禁裸男晨勃露j毛免费观看 | 波多野结衣一本一道 | 色一情一乱一乱一区91av | 影音先锋欧美资源 | 宝贝乖h调教灌尿穿环 | 美女爱爱爱 | 日韩欧美久久精品 | 蜜臀av免费在线观看 | 中文字幕亚洲国产 | 毛片基地免费 | 国产97在线 | 亚洲 | 大尺度在线观看 | 日皮视频免费观看 | 欧美亚洲另类视频 | 美女张开腿露出尿口 | 久久婷婷亚洲 | 女人扒开屁股让我添 | 91精品国产高清91久久久久久 | 久久久精品国产sm调教网站 | 日本精品一区二区三区四区的功能 | 免费性网站 | 精品爆乳一区二区三区 | 蜜芽一区二区 | 国内自拍视频在线播放 | 瑟瑟视频免费看 | 久久人妻免费视频 | 国产极品粉嫩 | 国产一区二区免费看 | 久久久久久国产精品无码 | 91干网| 成人av网站免费 | 国产在线观看不卡 | 亚洲精品乱码久久久久99 | 中文婷婷| 欧美人妖老妇 | 91亚洲国产成人精品一区 | 亚洲超碰在线观看 | 男女一区二区三区 | 色噜噜一区二区三区 | xxxxxxxx黄色片| 淫欲av| а√中文在线资源库 | 99爱免费| 国产毛片在线 | 国产精品免费无遮挡无码永久视频 | 中文字幕av高清片 | jzzijzzij亚洲成熟少妇18 欧美www在线观看 |