9 ответов:
вам действительно не нужен конкретный клиент, это довольно просто с большинством библиотек. Например, в jQuery вы можете просто вызвать generic
$.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или что-то еще.
в то время как вы можете использовать библиотеку, такую как excellent jQuery, вам не нужно: все современные браузеры очень хорошо поддерживают HTTP в своих реализациях JavaScript через XMLHttpRequest API, который, несмотря на свое название, не ограничивается 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 – к сожалению, я не могу рекомендовать конкретный. Вы можете найти этой ссылке удобно, правда.
вы можете использовать этот плагин 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 !' ); });Если вы нашли ошибки или хотите новые функции, разместите их на странице "проблемы" репозиториев, пожалуйста
jQuery имеет JSON-REST плагин со стилем REST шаблонов параметров URI. Согласно его описанию примером использования является следующее:
$.Read("/{b}/{a}", { a:'foo', b:'bar', c:3 })становится добраться до " / bar / foo?c=3".
для справки я хочу добавить о ExtJS, как описано в руководстве:RESTful Web Services. Короче говоря, способ использования, чтобы указать вам, разместить, поставить, удалить. Пример:
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' };
вы также можете использовать MVC-фреймворки, такие как Backbone.js, который обеспечит модель javascript данных. Изменения в модели будут переведены на остальные звонки.
вы можете попробовать спокойный.js, фреймворк-агностический клиент RESTful, использующий синтаксис, аналогичный популярному Restangular.
Dojo делает, например, через JsonRestStore, см. http://www.sitepen.com/blog/2008/06/13/restful-json-dojo-data/ .
вы можете использовать http://adodson.com/hello.js/ который имеет
- поддержка REST API
- встроенная поддержка многих сайтов google, facebook, dropbox
- Он поддерживает поддержку oAuth 1 и 2.
Comments