最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - jQuery Ajax async function don't fired on success - Stack Overflow

programmeradmin1浏览0评论

I have code like this:

jQuery("#test_btn").off("click").on("click", function () {
        jQuery.ajax({
                        type: "POST",
                        url: "/api/test/",
                        data: {
                            test: "me"
                        },
                        success: async function (response) {
                            alert("foo");
                        },
                        error: function (e) {
                            console.error(e);

                        }
                    });
        });

why the success function won't print an allert with "foo"? I nedd to use a promise function inside success... but nothing !

I have code like this:

jQuery("#test_btn").off("click").on("click", function () {
        jQuery.ajax({
                        type: "POST",
                        url: "/api/test/",
                        data: {
                            test: "me"
                        },
                        success: async function (response) {
                            alert("foo");
                        },
                        error: function (e) {
                            console.error(e);

                        }
                    });
        });

why the success function won't print an allert with "foo"? I nedd to use a promise function inside success... but nothing !

Share Improve this question edited Nov 16, 2019 at 13:48 r1si asked Nov 16, 2019 at 11:35 r1sir1si 1,1642 gold badges20 silver badges34 bronze badges 10
  • 1 await async function (response) - What is the intention behind this construct (which doesn't make any sense)? – Andreas Commented Nov 16, 2019 at 11:48
  • 1 The same question for .on("click", async function () { ... – Andreas Commented Nov 16, 2019 at 11:49
  • 1 @ThanhTrung I need call an async function inside success function.... – r1si Commented Nov 16, 2019 at 12:24
  • 1 You can create the async function inside the success callback – Kalimah Commented Nov 16, 2019 at 13:12
  • 1 success: async function (response) is still useless as it does not do/change anything – Andreas Commented Nov 16, 2019 at 14:23
 |  Show 5 more ments

4 Answers 4

Reset to default 5

I think your problem is that you are using an old JQuery version.

In 3.2.1 if you use an async function as feedback doesn't work

// find elements
var banner = $("#banner-message")
var button = $("button")

// handle click and add class
button.on("click", function() {
  banner.addClass("alt");
  jQuery.ajax({
    type: "POST",
    url: "/api/test/",
    data: {
      test: "me"
    },
    success: async function(response) {
      alert("Success!");
    },
    error: async function(e) {
      alert('O no, an error! :(');
      console.error(e);

    }
  });
})
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#banner-message {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  font-size: 25px;
  text-align: center;
  transition: all 0.2s;
  margin: 0 auto;
  width: 300px;
}

button {
  background: #0084ff;
  border: none;
  border-radius: 5px;
  padding: 8px 14px;
  font-size: 15px;
  color: #fff;
}

#banner-message.alt {
  background: #0084ff;
  color: #fff;
  margin-top: 40px;
  width: 200px;
}

#banner-message.alt button {
  background: #fff;
  color: #000;
}
<script src="https://cdnjs.cloudflare./ajax/libs/jquery/3.2.1/jquery.min.js"></script>

<div id="banner-message">
  <button>Send XHR request</button>
</div>

In 3.3.1 and above work perfectly

// find elements
var banner = $("#banner-message")
var button = $("button")

// handle click and add class
button.on("click", function() {
  banner.addClass("alt");
  jQuery.ajax({
    type: "POST",
    url: "/api/test/",
    data: {
      test: "me"
    },
    success: async function(response) {
      alert("Success!");
    },
    error: async function(e) {
      alert('O no, an error! :(');
      console.error(e);

    }
  });
})
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#banner-message {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  font-size: 25px;
  text-align: center;
  transition: all 0.2s;
  margin: 0 auto;
  width: 300px;
}

button {
  background: #0084ff;
  border: none;
  border-radius: 5px;
  padding: 8px 14px;
  font-size: 15px;
  color: #fff;
}

#banner-message.alt {
  background: #0084ff;
  color: #fff;
  margin-top: 40px;
  width: 200px;
}

#banner-message.alt button {
  background: #fff;
  color: #000;
}
<script src="https://cdnjs.cloudflare./ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="banner-message">
  <button>Send XHR request</button>
</div>

jQuery don't support async on callback need to use fetch api like this

await fetch("/api/test/", {
                        method: "post",
                        body:
                            'nonce=' + encodeURIComponent("<?= generate_nonce(); ?>") +
                            "&user_id=" + encodeURIComponent("<?= $_SESSION['user_id']; ?>") +
                            "&supername=" + encodeURIComponent("<?= $_REQUEST['bot_name']; ?>") +
                            "&name=" + encodeURIComponent(valore_base) +
                            "&simple=" + encodeURIComponent("check"),
                        headers:
                            {
                                "Content-Type": "application/x-www-form-urlencoded"
                            }

                    })
                        .then(async function (response) {
//success here 
});

another solution thanks to @Kalimah Apps is declare an async function inside success callback.... the basis is that the jQuery callback can't be async

jQuery("#test_btn").off("click").on("click", function () {
jQuery.ajax({
                type: "POST",
                url: "/api/test/",
                data: {
                    test: "me"
                },
                success: function (response) {

                    async function abc(response){
                        await my_sync_func(response);
                        alert("done after async")
                    }
                    abc(response);
                },
                error: function (e) {
                    console.error(e);

                }
});

});

AJAX(Asynchronous Javascript and XML) by its name it is clearly understood that the AJAX request is always asynchronous.

If you want it to be synchronous just add this,

$.ajaxSetup({
  async: false //by default it will be true
}); 

In addition to that,

The jQuery post() method sends an asynchronous http POST request to the server to submit the data to the server and get the response.

$.post('/jquery/submitData',   // url
   { myData: 'This is my data.' }, // data to be submit
   function(data, status, jqXHR) {
     // success callback
    })

Syntax:

$.post(url,[data],[callback],[type]);

Please refer this API documentation for further information. This would be helpful.

As the JairSnow's way, my app are using jQuery 2.2.4. And I must have following code to use jQuery 3.4.1 parallel with jQuery 2.2.4 (and I am using ASP.NET MVC):

In the index.cshtml, I added following code:

<!-- load jQuery 3.4.1 -->
    <script type="text/javascript" src="~/lib/jquery3.4.1/jquery.js" asp-append-version="true"></script>
    <script type="text/javascript">
        var jQuery_3_4_1 = $.noConflict(true);
    </script>

In javascript, I added following code:

jQuery_3_4_1.ajax({
            type: 'GET',
            url: '/Product/GetById',
            data: { id: id },
            dataType: "json",
            success: async function (item) {
                // ... my code...
                let productData;
                productData = await getFactor();
                // ... my code...
            },
            error: function (err) {
                general.notify('Error', 'error');
                console.log(err);
            }
        });
    }

And it run successfully. You can refer way to use multiple jQuery version here: Can I use multiple versions of jQuery on the same page?

发布评论

评论列表(0)

  1. 暂无评论