jQuery validate插件submitHandler提交导致死循环解决方法

作者:海底苍鹰

地址:http://blog.51yip.com/jsjquery/1511.html

dom对像的提交form.submit();和jquery对像的提交$('').submit();功能上是没有什么区别的。但是如果用了jquery validate插件,提交时这二个就区别大了。$('').submit();提交时,

jquery validate会进行验证,submitHandler里面如果写了$('').submit();会导致死循环,而form.submit();则不会。

一,简单说一下dom对像和jquery对像

dom对像,你要用js的写法来操作,页面中的标签。而jquery对像呢,你要用jquery的语法来操作。

dom对像转换成jquery的对像呢,也很简单,就加上$()这个就行了,然后就可以用jquery的语法来操作,页面中的标签了。我想大家用的最多就是this了。

$('input[name^="hour"]').each(function(index){  
  1.     this.value=index;        //this是dom对像,js写法  

  2. });  
  3.   
  4. $('input[name^="hour"]').each(function(index){  

  5.     $(this).val(index);      //$(this)是jquery对像,jquery写法  

  6. });  

二,jquery validate 死循环程序

$("#product_form").validate({  
  1.     focusInvalid:false,  

  2.     submitHandler: function(form){  

  3.         $('.submit').submit();  

  4.     }  

  5. });  

正确写法,

$("#product_form").validate({  
  1.     focusInvalid:false,  

  2.     submitHandler: function(form){  

  3.         form.submit();  

  4.     }  

  5. });  

出现死循环的时候,浏览器会一直处于加载中,直到浏览器挂掉,这个时候,可以加一个alert,你就会知道,validate一直在循环验证。个人觉得,虽然是个小问题,但是很难想起来。

你可能感兴趣的:(js,jquery,jquery,插件,javascript)