源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

jQuery Validation插件remote验证方式的Bug解决

  • 时间:2020-11-19 21:50 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery Validation插件remote验证方式的Bug解决
不过奇怪的是,最近用下来感觉有些古怪,因为好像有些死板,已有功能的应变能力还不强,甚至还有个奇怪的Bug。任何项目有Bug其实也正常,但这个Bug其实是一个文档上已经记载了,却没有实现的功能,这就有些说不过去了。这个问题便出在remote验证方式上,还好修改起来非常容易,在此记录一下,也方便以后的参考。 在表单验证时,有时候会需要发一个AJAX请求去服务器上进行判断,例如在用户注册时检查用户名是否存在。jQuery Validation插件提供了一种remote方式来实现这一点。例如我可以这样验证表单:
[url=http://docs.jquery.com/Plugins/Validation/Methods/remote#options]文档描述[/url],此时我们应该这样写:
[u]复制代码[/u] 代码如下:
$('#regForm').validate({ 'rules': { 'user.Name': { 'remote': { url: '/account/verify', data: { name: function() { return $("#userName").val(); } }}}}});
可是,从实际效果来看,jQuery还是在请求“/account/verify?user.Name=jeffz”,百思不得其解。确认在三之后只得求助于jquery.validation.js源码,看后差点晕过去:
[u]复制代码[/u] 代码如下:
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) { ...
我很奇怪,不知道为什么会这样做,这样根本没有起到指定参数名的作用。那么,改吧:
[u]复制代码[/u] 代码如下:
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类似的文件只能自己进行压缩了。 居然会出现这样的问题,实在令人费解。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部