ajax - südhessen - Zwei $.post-Anfragen nacheinander. Die zweite $.post-Anfrage wird nicht ausgeführt



südhessen post (1)

$.post() ist eine abgekürzte Form der $ .ajax () - Struktur. Normalerweise ziehe ich es vor, die $.ajax() Struktur zu verwenden, weil:

  • Es ist einfacher zu sehen, ob ich etwas verpasst habe
  • Ich kann leichter zusätzliche Parameter hinzufügen, z. B. asynch: false,
  • Als ich Ajax neu fand, fand ich es wesentlich einfacher, diese Struktur zu beheben

In Ihrem Fall könnten Sie Ihr Problem leichter in einer $.ajax() Struktur lösen, da es einfacher wäre zu sehen, dass ein zweiter Ajax-Aufruf (der vom Ergebnis eines ersten Ajax-Aufrufs abhängt) im Erfolg geschehen muss. Funktion des ersten Ajax-Aufrufs .

Hier ist ein eigenständiges Beispiel (zu schlecht, dass jsFiddle nicht mit Ajax umgehen kann ...):

TESTER.PHP

<html>
    <head>
        <script src="//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" id="eml" /><br />
    Password: <br />
    <input type="password" id="pw" /><br />
    <input type="button" id="mybutt" value="Submit">

</body>
</html>

deinephp.php

<?php

if (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;
}

Ich habe eine Javascript-Funktion, in der ich zwei $ .post-Anfragen habe. Beide $ .post-Anfragen sollten ausgeführt werden. Aber manchmal wird die zweite $ .post-Anfrage nicht ausgeführt. Was könnte der Grund dafür sein?





jquery