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

javascript - Basic "Raw" Ajax Call - Stack Overflow

programmeradmin0浏览0评论

I have a serverside function:

string foo(string input_string);

for example:

foo("bar") returns "baz"

and have wrapped this function into a HTTP server such that:

POST /foo HTTP/1.1
...

bar

will return:

HTTP/1.1 200 OK
...

baz

ie a POST request with the input string as the HTTP Message Body will return the output string as the HTTP Message Body of the 200 OK.

Now in my javascript on the web page I have two functions:

function sendFoo(input_string)
{
   ??? // should asynchronously start process to POST input_string to server
}

function recvFoo(output_string)
{
   ...
}

When I call sendFoo I would like the POST to be made asynchronously to the server and later when the response is received I would like recvFoo called (perhaps in another thread or whatever) with the Message Body of the 200 OK.

How do I implement sendFoo above? I am currently using jQuery, but a solution in pure javascript is ok too. (I can also modify the server if need be?)

Solution:

function sendFoo(input_string)
{
   $.ajax({ url: "/foo", type: "POST", data: input_string, success: recvFoo });
}

I have a serverside function:

string foo(string input_string);

for example:

foo("bar") returns "baz"

and have wrapped this function into a HTTP server such that:

POST /foo HTTP/1.1
...

bar

will return:

HTTP/1.1 200 OK
...

baz

ie a POST request with the input string as the HTTP Message Body will return the output string as the HTTP Message Body of the 200 OK.

Now in my javascript on the web page I have two functions:

function sendFoo(input_string)
{
   ??? // should asynchronously start process to POST input_string to server
}

function recvFoo(output_string)
{
   ...
}

When I call sendFoo I would like the POST to be made asynchronously to the server and later when the response is received I would like recvFoo called (perhaps in another thread or whatever) with the Message Body of the 200 OK.

How do I implement sendFoo above? I am currently using jQuery, but a solution in pure javascript is ok too. (I can also modify the server if need be?)

Solution:

function sendFoo(input_string)
{
   $.ajax({ url: "/foo", type: "POST", data: input_string, success: recvFoo });
}
Share Improve this question edited Dec 16, 2020 at 8:11 Adam Zalcman 27.3k4 gold badges74 silver badges94 bronze badges asked Feb 4, 2012 at 17:54 Andrew TomazosAndrew Tomazos 68.8k44 gold badges204 silver badges345 bronze badges 4
  • you can use Jquery ajax via post right ? – kobe Commented Feb 4, 2012 at 18:01
  • Are you still having difficulties? – gdoron Commented Feb 4, 2012 at 18:50
  • trying out suggested solutions shortly, starting with yours. in chrome i notice that it trys to send an "OPTIONS" request first. Also if the URL is bad I get no error message, but I guess that is unavoidable. – Andrew Tomazos Commented Feb 4, 2012 at 19:13
  • you can add to ajax a callback for error, success: recvFoo, error: errorFunction – gdoron Commented Feb 5, 2012 at 1:05
Add a ment  | 

3 Answers 3

Reset to default 6

XMLHttpRequest object's open() method allows you to specify the HTTP method while the send() method allows to specify the message body, e.g.

var xhr = ... // obtain XMLHttpRequest object
xhr.open('POST', '/foo'); // HTTP method and requested URL.
xhr.onreadystatechange = function() {
  if (xhr.readyState == 4 && xhr.status == 200) {
      recvFoo(xhr.responseText); // Will pass 'baz' to recvFoo().
  }
};
xhr.send('bar'); // Message body with your function's argument.

No need to fallback to classic JavaScript

$.ajax({
        url:"URL of foo...",
        type: "POST",
        data: "what ever",
        success: recvFoo
       });

Or the post option:

  $.post('The url of foo', {input_string : 'bar'}, recvFoo);

jQuery post will do the job:

$.post('foo.html', {'varname' : 'bar'}, function(data) {
  recvFoo(data);
});

Very well laid out question, thanks.

发布评论

评论列表(0)

  1. 暂无评论