JavaScript REST client Library [closed] JavaScript REST client Library [closed] jquery jquery

JavaScript REST client Library [closed]


You don't really need a specific client, it's fairly simple with most libraries. For example in jQuery you can just call the generic $.ajax function with the type of request you want to make:

$.ajax({    url: 'http://example.com/',    type: 'PUT',    data: 'ID=1&Name=John&Age=10', // or $('#myform').serializeArray()    success: function() { alert('PUT completed'); }});

You can replace PUT with GET/POST/DELETE or whatever.


While you may wish to use a library, such as the excellent jQuery, you don't have to: all modern browsers support HTTP very well in their JavaScript implementations via the XMLHttpRequest API, which, despite its name, is not limited to XML representations.

Here's an example of making a synchronous HTTP PUT request in JavaScript:

var url = "http://host/path/to/resource";var representationOfDesiredState = "The cheese is old and moldy, where is the bathroom?";var client = new XMLHttpRequest();client.open("PUT", url, false);client.setRequestHeader("Content-Type", "text/plain");client.send(representationOfDesiredState);if (client.status == 200)    alert("The request succeeded!\n\nThe response representation was:\n\n" + client.responseText)else    alert("The request did not succeed!\n\nThe response status was: " + client.status + " " + client.statusText + ".");

This example is synchronous because that makes it a little easier, but it's quite easy to make asynchronous requests using this API as well.

There are thousands of pages and articles on the web about learning XmlHttpRequest — they usually use the term AJAX – unfortunately I can't recommend a specific one. You may find this reference handy though.


You can use this jQuery plugin I just made :)https://github.com/jpillora/jquery.rest/

Supports basic CRUD operations, nested resources, basic auth

  var client = new $.RestClient('/api/rest/');  client.add('foo');  client.foo.add('baz');  client.add('bar');  client.foo.create({a:21,b:42});  // POST /api/rest/foo/ (with data a=21 and b=42)  client.foo.read();  // GET /api/rest/foo/  client.foo.read("42");  // GET /api/rest/foo/42/  client.foo.update("42");  // PUT /api/rest/foo/42/  client.foo.delete("42");  // DELETE /api/rest/foo/42/  //RESULTS USE '$.Deferred'  client.foo.read().success(function(foos) {    alert('Hooray ! I have ' + foos.length + 'foos !' );  });

If you find bugs or want new features, post them in the repositories 'Issues' page please