$.post()是$ .ajax()结构的缩写形式。我通常更喜欢使用该$.ajax()结构,因为:
比较容易发现我是否错过了任何事情我可以更轻松地添加其他参数,例如 asynch: false,当刚接触ajax时,我发现对这种结构进行故障排除要容易得多在您的情况下,您可能会发现在$.ajax()结构中更容易解决问题,因为更容易看到在第一个ajax的成功函数中必须进行第二个ajax调用(取决于第一个ajax调用的结果)打电话 。
这是一个独立的示例(太糟糕的jsfiddle无法处理ajax …):
测试器
<html> <head><script src='https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js'></script><script type='text/javascript'> $(document).ready(function() {$(’#eml’).focus();$(’#mybutt’).click(function() { var $a = $(’#eml’).val(); var $b = $(’#pw’).val(); //alert(’Email: ’ +$a+ ’ Pass: ’ +$b); $.ajax({type:'POST',url: 'yourPHPfile.PHP',data: ’email=’ +$a+ ’&pass=’ +$b,success: function(data) { alert(data); var aData = data.split(’|’); var name = aData[0]; var code = aData[1]; alert(’Name: ’ +name+ ’ Code: ’ +code); $.ajax({type:'POST',url: 'yourPHPfile.PHP',data: ’name=’ +name+ ’&code=’ +code,success: function(newdata) { alert(newdata);} //END success_ajax2 }); //END ajax() #2} //END success_ajax1 }); //END ajax() #1}); //END mybutt.click() }); //END $(document).ready()</script> </head><body> Email: <br /> <input type='text' /><br /> Password: <br /> <input type='password' /><br /> <input type='button' value='Submit'></body></html>
<?PHPif (isset($_POST[’email’])) { $e = $_POST[’email’]; $p = $_POST[’pass’]; $name = ’Bob’; $code = ’1234’; $resp = $name .’|’. $code; echo $resp;}else if (isset($_POST[’name’])) { $n = ’<h1>Here is something new</h1>’; echo $n;}解决方法
我有一个javascript函数,其中有两个$ .post请求。两个$ .post请求都应该执行。但是有时候,第二个$.post请求却没有执行。这可能是什么原因?