javascript - 防止垃圾邮件异步调用的好方法

标签 javascript ajax

我遇到了一个问题,我认为我找到了可行的解决方案。 但为了确保我愿意面对公众批评家。

我有一个可以触发 ajax 调用的小应用程序。

这些电话可能需要一些时间才能回复。

  • 我最讨厌的情况是,用户点击多次会发送大量请求,而结果却以最快的速度平静地返回。
  • 我也不愿意知道我的用户(一旦他变得聪明并治愈了他严重的全身性点击症*病例)没有得到他调用的最后一个操作的结果。

所以为了避免这种情况,我认为我可以:

  • 告诉我的函数了解它是否已经被调用并正在等待响应。
  • 如果是,那么它会存储对它所做的任何其他调用,然后什么都不做返回。
    • 任何进一步的调用都会压缩存储的调用,因为我只想保留一个调用(最后一个)。
  • 执行回调时,它会检查是否有调用挂起。
    • 如果没有调用在等待,那么它会正常运行
    • 如果调用处于挂起状态,它会跳过它的正常行为,只调用使用挂起数据集触发 ajax 调用的方法,清除存储挂起调用的变量

这是我的代码:

function bob(i) {

    var me = this;
    if (this.isFetching === undefined) {
        this.isFetching = false;
    }
    if (this.isFetching) {
        this.nextFetch = i;
        return;
    } else {
        this.isFetching = true;
    }
    yourFavoriteAjaxCallerMethod({
        url: 'http://this_server_does_not_exist.net/this.is?an=example',
        data: {
            json: JSON.encode({
                bob: i
            }),
            delay: 2
        },
        onSuccess: function (response) {
            console.log(response.bob);
            me.isFetching = false;
            if (me.nextFetch !== undefined) {
                var nextFetch = me.nextFetch;
                delete me.nextFetch;
                bob(nextFetch);
                return;
            }
            alert(response.bob);
        }
    }).send();
}

为了澄清这一切,我制作了一个可以正常工作的 jsFiddle,它应该是不言自明的:http://jsfiddle.net/LhermitteG/L8kqa/

到目前为止,一切正常,这很好,但我的问题是:

Do I do it right ?

Is there a design pattern about this ?

If I did it wrong, what is bad ?

How could I improve it ?

Am I missing something ?

You know I am ... I always miss something :(

Yeah I know I have insecurities issues that I should address ...

-* 我确定这是一种真正的疾病,它必须是,它是真实的,我已经看到了!

最佳答案

对于事件减少,您正在谈论去抖动。 http://benalman.com/projects/jquery-throttle-debounce-plugin/有一个 jquery debounce 方法,和 http://underscorejs.org/#debounce有自己的实现。

问题的第二部分在自动完成中很典型 - 在一般搜索中,用户首先键入的字符较少,导致更大且通常更慢的响应。当他们键入更多信息时,查询会更长,但响应速度会更快,因为搜索查询返回的匹配项更少且负载更小。需要确保最后最多响应的软件模式是相关标识符模式 (163),我认为最好在此处展示它:http://www.slideshare.net/kevinhakanson/implementing-messaging-patterns-in-java-script-using-the-openajax-hub - 参见幻灯片 45。

如果这看起来太棘手,接受最后一个请求并将关联的(消息)id 存储到回调处理程序中,或者在 javascript 中,或者如果您可以从服务器回显它,那是映射一对一请求的理想选择.如果有任何请求返回,请检查它们是否具有最新的(消息)id,如果没有,则应安全地忽略它们。

关于javascript - 防止垃圾邮件异步调用的好方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24129232/

相关文章:

javascript - 当禁用 tableDnD 时,它会留下残留的 css,我无法清除 css

javascript - 在未知数量的 div 容器之间切换(隐藏/显示)

jsFiddle 中的 AJAX

javascript - 如何获取父节点的子节点并使用 jquery ajax 处理它

javascript - 以字节流形式下载 PDF

JavaScript 附加事件

javascript - 用于构造数组的 PHP 等效于 JavaScript 传播语法的是什么?

javascript - PHP、JS、AJAX 无法向数据库发送值

javascript - 如何使用 AJAX 和 PHP 生成 .doc

javascript - 等待 jQuery AJAX 调用完成