我完全被这个问题所困扰,我很想就我做错了什么或者我可以做些什么来调试问题提出建议。
我有 jquery 验证引擎验证表单。例如,检查屏幕名称是否存在的代码如下;
<input value="[% fields.screenname | html %]" placeholder="Screenname"
onclick="$('#screenname').validationEngine('showPrompt', 'For example: JohnDoe_68.', 'load')"
class="validate[required,custom[onlyLetterNumber],maxSize[41],ajax[ajaxNameCallPerlScreenname]]"
name="screenname" id="screenname" type="text" size= "41" maxlength="24" data-prompt-position="centerRight"/>
对验证引擎的调用是
jQuery(document).ready(function(){
jQuery("#register").validationEngine('attach', 'autoHidePrompt', {
promptPosition : "topRight",
scroll: "false",
ajaxFormValidation : "true",
onBeforeAjaxFormValidation: "beforeCall",
onAjaxFormComplete: "ajaxValidationCallback"
});
});
在这个阶段,beforeCall 和 ajaxValidationCallback 函数直接来自演示,并且永远不会被调用,所以我不会在此处包含它们。
在服务器端,我有一个简单的脚本检查是否使用该用户名并通过用 perl 编写的脚本返回 json(utf8 编码)。相关代码是;
use utf8;
my $output;
eval { $output = JSON::XS->new->utf8->encode( $data ); };
if($@)
{
use Carp;
confess($@);
}
warn "Form Output is " . $output;
$self->discard_request_body();
$self->req->content_type('application/json; charset=utf-8');
$self->req->headers_out->set( 'Expires' => 'Thu, 1 Jan 1970 00:00:00 GMT' );
$self->req->headers_out->set( 'Content-Length' => length $output );
$self->req->print($output);
这就是麻烦开始的地方。在 chrome 和 firefox 中,我可以看到验证请求到达服务器,我可以看到正确的响应被发送回浏览器,我可以在浏览器中查看正确的响应(我认为),就像这样
[["screenname","false","That user name is already taken. Please try again."]]
但是实际的 onAjaxFormComplete 永远不会被调用。如果我在 beforeCall 和 ajaxValidationCallback 函数中设置断点,它们永远不会被调用。
标头如下;
Response Headers
Connection Keep-Alive
Content-Encoding gzip
Content-Length 89
Content-Type application/json; charset=utf-8
Date Sat, 19 May 2012 19:47:28 GMT
Expires Thu, 1 Jan 1970 00:00:00 GMT
Keep-Alive timeout=15, max=100
Server Apache/2.2.16 (Debian)
Vary User-Agent,Accept-Encoding
X-UA-Compatible chrome=1
X-What-Alias flooting
Request Headers
Accept application/json, text/javascript, */*; q=0.01
Accept-Encoding gzip, deflate
Accept-Language en-us,en;q=0.5
Connection keep-alive
Cookie flooting_session=be8aec0e39f12ee031c9103072b19a66
Host six.flooting.com
Referer http://six.flooting.com/register
User-Agent Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:12.0) Gecko/20100101 Firefox/12.0
X-Requested-With XMLHttpRequest
这就是我目前能告诉你的全部内容。我想我在配置回调函数的方式上遗漏了一些非常简单的东西,但是我已经为此苦苦挣扎了一段时间,而且我离答案还没有更近。
注意 beforeCall 不会在 ajax 请求之前被调用,但是我已经在validationEngine 中的代码的适当部分(应该调用 beforeCall 的地方)设置了断点,并且执行永远不会到达它。甚至没有进入父函数。
有人看到我错过了什么吗?