3

我一直在研究 ajax 调用的 google 闭包库,并且我经历了一个看起来像这样的示例:

goog.events.listen(request, "complete", function(){
  if (request.isSuccess()) {
    // do something cool
   } else {
     // display an apologize message
   }
});

与看起来像这样的 jquery 示例相反:

$.ajax({url: url, success: function () { }, error: function () { }});

我已经看到更多谷歌关闭弹出窗口,但在这种情况下会有什么优势或劣势?对于像这样的 ajax 相关调用,jquery 库调用似乎要简单得多。

4

1 回答 1

5

您的 Closure 示例不完整。我假设就在您的示例之前,您创建了一个XhrIo实例并调用send()了它。

如果您想要一个更简单的 Closure 等效于您发布的 jQuery 示例,您可以使用 static XhrIo.send()。它看起来像这样:

goog.net.XhrIo.send(
  url,
  function(event) {
    var xhr = event.target;
    if (xhr.isSuccess()) {
      // do something cool
    } else {
      // display an apologize message
    }
  });

无可否认,这比 jQuery 版本更笨重。一般来说,Closure 在设计时考虑到了面向对象的编程(与主要是静态函数的 jQuery 形成鲜明对比)。这可能适合您或不适合您,这取决于您是否喜欢以面向对象的方式编写 JS 代码。

在这种特殊情况下,如果您创建一个XhrIo可重复用于多个请求的对象(例如,您可以setTimeoutInterval()将其用于所有请求),您可能会从 Closure 中获得一点优势。如果您关心内存,Closure 还可以让您更明确地控制垃圾收集。

于 2013-01-11T00:54:28.080 回答