WEB开发网
开发学院网页设计JavaScript jQuery Validation插件remote验证方式的Bug 阅读

jQuery Validation插件remote验证方式的Bug

 2009-12-11 00:00:00 来源:WEB开发网   
核心提示: <formid="regForm"><inputtype="text"id="userName"name="user.Name"/></form>与此同时,我们用来进行验证的Act

<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类似的文件只能自己进行压缩了。

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

文章出处:http://www.cnblogs.com/JeffreyZhao/archive/2009/12/04/jquery-validate-remote-bug.html

上一页  1 2 

Tags:jQuery Validation 插件

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接