如何避免使用超级代理进行重复的api调用? [关闭]

问题描述 投票:-2回答:1

我有一个api调用,该调用使用superagent返回了一些数据。 Api称为按钮单击,因此当我多次单击按钮时,api称为多次。为了避免这种情况,我禁用了第一次单击时的按钮。但是如果在某个时间范围内多次调用api,有什么办法可以使一个api调用使用superagent进入服务器。

superagent
1个回答
0
投票

您可以使用lodash _.debounce方法包装您的点击处理程序。

例如

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Static Template</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>
  </head>
  <body>
    <button id="btn" type="button">Call API</button>
    <script>
      window.onload = function() {
        const $btn = document.getElementById("btn");
        function clickHandler(e) {
          console.log("call api"); // Use superagent replace this line.
        }
        const clickHandlerDebounced = _.debounce(clickHandler, 1000, {
          trailing: true
        });
        $btn.addEventListener("click", clickHandlerDebounced, false);
      };
    </script>
  </body>
</html>

包装的单击处理程序-clickHandlerDebounced函数将在您最后一次单击后1000毫秒后触发,无论您单击按钮多少次。

您可以在此处找到示例:https://codesandbox.io/s/so-59452935-ehood

© www.soinside.com 2019 - 2024. All rights reserved.