JavaScript-библиотека клиента REST

Есть ли библиотека JavaScript, которая позволяет мне выполнять все операции REST, такие как (GET, POST, PUT и DELETE over HTTP или HTTPS)?

Ответ 1

Вам действительно не нужен конкретный клиент, он довольно прост в большинстве библиотек. Например, в jQuery вы можете просто вызвать общую $.ajax функцию с типом запроса, который вы хотите сделать:

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

Вы можете заменить PUT на GET/POST/DELETE или что-то еще.

Ответ 2

Хотя вы можете использовать библиотеку, такую ​​как отличный jQuery, вам не нужно: поддержка всех современных браузеров HTTP очень хорошо в своих реализациях JavaScript через API XMLHttpRequest, который, несмотря на свое имя, не ограничивается представлениями XML.

Вот пример выполнения синхронного запроса HTTP PUT в 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 + ".");

Этот пример является синхронным, потому что это делает его немного проще, но довольно легко сделать асинхронные запросы, используя этот API.

В Интернете есть тысячи страниц и статей об обучении XmlHttpRequest - они обычно используют термин AJAX - к сожалению, я не могу рекомендовать конкретный. Тем не менее вы можете найти эту ссылку.

Ответ 3

Вы можете использовать этот плагин jQuery, который я только что сделал:) https://github.com/jpillora/jquery.rest/

Поддерживает основные операции CRUD, вложенные ресурсы, 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 !' );
  });

Если вы обнаружите ошибки или хотите новые функции, разместите их на странице "Проблемы" в репозиториях, пожалуйста,

Ответ 4

jQuery имеет JSON-REST плагин с стилем REST стиля шаблонов параметров URI. В соответствии с его описанием примером использования является следующее: $.Read("/{b}/{a}", { a:'foo', b:'bar', c:3 }) становится GET для "/bar/foo? C = 3".

Ответ 5

Для справки я хочу добавить о ExtJS, как описано в Руководстве: RESTful Web Services. Короче говоря, используйте метод для указания GET, POST, PUT, DELETE. Пример:

Ext.Ajax.request({
    url: '/articles/restful-web-services',
    method: 'PUT',
    params: {
        author: 'Patrick Donelan',
        subject: 'RESTful Web Services are easy with Ext!'
    }
});

Если заголовок Accept необходим, его можно установить по умолчанию для всех запросов:

Ext.Ajax.defaultHeaders = {
    'Accept': 'application/json'
};

Ответ 6

Вы также можете использовать инфраструктуру mvc, например Backbone.js, которая предоставит javascript-модель данных. Изменения в модели будут переведены на вызовы REST.

Ответ 7

Вы можете попробовать restful.js, клиент RESTful с каркасом-агностиком, используя синтаксис, подобный популярному Restangular.

Ответ 9

Вы можете использовать http://adodson.com/hello.js/, у которого

  • Поддержка API поддержки
  • Встроенная поддержка многих сайтов google, facebook, dropbox
  • Он поддерживает поддержку oAuth 1 и 2.