jQuery Validation插件remote验证方式的Bug解决 |
不过奇怪的是,最近用下来感觉有些古怪,因为好像有些死板,已有功能的应变能力还不强,甚至还有个奇怪的Bug 。任何项目有Bug其实也正常,但这个Bug其实是一个文档上已经记载了,却没有实现的功能,这就有些说不过去了 。这个问题便出在remote验证方式上,还好修改起来非常容易,在此记录一下,也方便以后的参考 。 在表单验证时,有时候会需要发一个AJAX请求去服务器上进行判断,例如在用户注册时检查用户名是否存在 。jQuery Validation插件提供了一种remote方式来实现这一点 。例如我可以这样验证表单: 复制代码 代码如下: <form id="regForm"> <input type="text" name="userName" /> </form> <script language="javascript"> $(#regForm).validate({ rules: { userName: { required: true, remote: /account/verify }}); </script> 这样,jQuery Validation便会请求“/account/verify?userName=jeffz”这样的URL来获取true/false 。可惜的是,我们在使用ASP.NET MVC时,往往会将input的name写为特定的形式,目的是利用DefaultModelBinder的强大绑定功能 。例如: <form id="regForm"> <input type="text" id="userName" name="user.Name" /> </form> 与此同时,我们用来进行验证的Action方法,它的参数名可能也有所不同: 复制代码 代码如下: public ActionResult Verify(string name) { ... } 根据文档描述,此时我们应该这样写: 复制代码 代码如下: $(#regForm).validate({ rules: { user.Name: { remote: { url: /account/verify, data: { name: function() { return $("#userName").val(); } }}}}}); 可是,从实际效果来看,jQuery还是在请求“/account/verify?user.Name=jeffz”,百思不得其解 。确认在三之后只得求助于jquery.validation.js源码,看后差点晕过去: 复制代码 代码如下: remote: function(value, element, param) { if ( this.optional(element) ) return "dependency-mismatch"; ... param = typeof param == "string" && {url:param} || param; if ( previous.old !== value ) { previous.old = value; var validator = this; this.startRequest(element); var data = {}; data[element.name] = value; // data还是以element.name为准? $.ajax($.extend(true, { url: param, mode: "abort", port: "validate" + element.name, dataType: "json", data: data, success: function(response) { ... 我很奇怪,不知道为什么会这样做,这样根本没有起到指定参数名的作用 。那么,改吧: 复制代码 代码如下: remote: function(value, element, param) { if (this.optional(element)) return "dependency-mismatch"; ... param = typeof param == "string" && {url:param} || param; if (previous.old !== value) { previous.old = value; var validator = this; this.startRequest(element); var data = {}; data[element.name] = value; $.ajax($.extend(true, { // url: param, url: param.url, mode: "abort", port: "validate" + element.name, dataType: "json", // data: data, data: param.data || data, success: function(response) { ... 修改两处即可,问题就此解决 。只可惜,jquery.validate.min.js类似的文件只能自己进行压缩了 。 居然会出现这样的问题,实在令人费解 。 |