当前位置:  开发笔记 > 编程语言 > 正文

JavaScript REST客户端库

如何解决《JavaScriptREST客户端库》经验,为你挑选了5个好方法。

是否有一个JavaScript库,它允许我执行像(所有的REST操作GET,POST,PUTDELETE超过HTTPHTTPS)?



1> aleemb..:

您并不真正需要特定的客户端,大多数库都相当简单.例如,在jQuery中,您可以$.ajax使用您要进行的请求类型调用泛型函数:

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

您可以替换PUTGET/ POST/ DELETE或什么的.


jQuery还包括一些使用GET和POST的便捷快捷方法:http://api.jquery.com/category/ajax/shorthand-methods/
从技术上讲,这不是一个REST客户端,它是一个HttpClient.我正在寻找能够正确使用链接关系和媒体类型来驱动状态的东西.会继续寻找......
你如何检索响应的主体?标题?

2> Avi Flax..:

虽然您可能希望使用库,例如​​优秀的jQuery,但您不必:所有现代浏览器都通过XMLHttpRequest API在其JavaScript实现中非常好地支持HTTP ,尽管XMLHttpRequest API的名称不仅限于XML表示.

以下是在JavaScript中生成同步HTTP PUT请求的示例:

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> jpillora..:

你可以使用我刚刚制作的这个jQuery插件:) https://github.com/jpillora/jquery.rest/

支持基本的CRUD操作,嵌套资源,基本身份验证

  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> Volodymyr Fr..:

jQuery具有带有REST风格的URI参数模板的JSON-REST插件.根据其描述使用的例子是以下:$.Read("/{b}/{a}", { a:'foo', b:'bar', c:3 })成为"/ bar/foo?c = 3"的GET.



5> stivlo..:

作为参考,我想添加有关ExtJS的内容,如手册:RESTful Web服务中所述.简而言之,使用方法来指定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'
};

推荐阅读
U友50081205_653
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有