今天碰到一个Bug,在IE8中,日期验证失效,输入正确的日期格式也会验证失败,提示:xxx必须是日期格式(the field xxx must be a date)
最终找到问题所在:jquery.validate.js
// http://docs.jquery.com/Plugins/Validation/Methods/date date: function ( value, element ) { return this .optional(element) || !/Invalid|NaN/.test( new Date(value).toString()); }, |
这段代码会有什么问题呢:在IE6,7,8 newData('2013-08-13') 是会返回 NaN 的,所以会验证通不过。
将上面的代码改为下面的代码就不会出错了
date: function ( value, element ) { return this .optional(element) || !/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/.test( new Date(value).toString()); }, |
当然不建议在原来插件中修改,复制一个新的文件,改名为jquery.validate.plus.js,将该文件中的方法改了,然后在页面引用的时候做一个浏览器的判断:
<!--[ if lt IE 9]> <script type= "text/javascript" src= "@Url.Content(" ~/Scripts/jquery.validate.plus.js ")" ></script> <![endif]--> |
这样就解决问题了。但要注意JS的载入顺序:
<script type="text/javascript" src="/Scripts/jquery.validate.js"></script> <script type="text/javascript" src="/Scripts/jquery.validate.plus.js"></script>
注:
[if lt IE 9]是指IE版本小于IE9的,对IE CSS hack不熟悉的请阅读:http://js8.in/381.html
朋友们,多添加一个JS,按理来说后者会覆盖前者,问题是能够的,但是也许会导致其它莫名其妙的问题,所以为了妥善起见,你只需要在页面上加入以下代码就可以解决这个Bug,而且不会有任何副作用哦。
<!--[ if lt IE 9]> <script type= "text/javascript" > $( function () { $.validator.methods.date = function (value, element) { return this .optional(element) || !/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/.test( new Date(value).toString()); }; }); </script> <![endif]--> |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构