我仍然在努力摆脱JQUERY,AJAX和PHP的束缚。
我现在可以调用PHP OK,处理表单元素并发送电子邮件,但是我不处理返回AJAX的问题。我总是error:激活选择器,当我尝试列出返回的JSON时,我得到了信息,这显然是错误的。
error:
PHP具有假定的JSON返回
<?php touch('phpTouch.txt'); // process email $email=1; if ($email) { $value = array('return' => 1, 'msg1' => 'Message sent OK, we will be in touch ASAP'); } else { $value = array('return' => 0, 'msg1' => 'Message Failed, please try later'); } $output = $json->encode($value); echo $output; ?>
Javascript和AJAX
function submitForm(evt) { $('#msgid').html('<h1>Submitting Form (External Routine)</h1>'); if ($('#formEnquiry').valid() ) { $("#msgid").append("<h1>(Outside Ready) VALIDATED send to PHP</h1>"); $.ajax({ url: "ContactFormProcess3.php", type: "POST", data: $('#formEnquiry').serialize(), dataType: "json", success: function (data) { alert("SUCCESS:"); for(var key in data) { $('#msgid').append(key); $('#msgid').append('=' + data[key] + '<br />'); } }, error: function (data) { alert("ERROR: "); for(var key in data) { $('#msgid').append(key); $('#msgid').append('=' + data[key] + '<br />'); } } }); } else { $('#msgid').append('<h1>(Outside Ready) NOT VALIDATED</h1>'); } evt.preventDefault(); };
假定的JSON数据清单
readyState=4 setRequestHeader=function (a,b){if(!s){var c=a.toLowerCase();a=m[c]=m[c]||a,l[a]=b}return this} getAllResponseHeaders=function (){return s===2?n:null} getResponseHeader=function (a){var c;if(s===2){if(!o){o={};while(c=bF.exec(n))o[c[1].toLowerCase()]=c[2]}c=o[a.toLowerCase()]}return c===b?null:c} overrideMimeType=function (a){s||(d.mimeType=a);return this} etc etc
如果有人能建议我犯了什么愚蠢的错误,那么我将不胜感激。
您可以通过以下方式在PHP中返回json:
header('Content-Type: application/json'); echo json_encode(array('foo' => 'bar')); exit;