jQuery Validation插件remote验证方式的Bug解决_Javascript教程-查字典教程网
jQuery Validation插件remote验证方式的Bug解决
jQuery Validation插件remote验证方式的Bug解决
发布时间:2016-12-30 来源:查字典编辑
摘要:不过奇怪的是,最近用下来感觉有些古怪,因为好像有些死板,已有功能的应变能力还不强,甚至还有个奇怪的Bug。任何项目有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类似的文件只能自己进行压缩了。

居然会出现这样的问题,实在令人费解。

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类