Blame view

node_modules/resize-observer-polyfill/src/utils/throttle.js 2.1 KB
2a09d1a4   liuqimichale   添加宜春 天水 宣化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
  import requestAnimationFrame from '../shims/requestAnimationFrame.js';
  
  // Defines minimum timeout before adding a trailing call.
  const trailingTimeout = 2;
  
  /**
   * Creates a wrapper function which ensures that provided callback will be
   * invoked only once during the specified delay period.
   *
   * @param {Function} callback - Function to be invoked after the delay period.
   * @param {number} delay - Delay after which to invoke callback.
   * @returns {Function}
   */
  export default function (callback, delay) {
      let leadingCall = false,
          trailingCall = false,
          lastCallTime = 0;
  
      /**
       * Invokes the original callback function and schedules new invocation if
       * the "proxy" was called during current request.
       *
       * @returns {void}
       */
      function resolvePending() {
          if (leadingCall) {
              leadingCall = false;
  
              callback();
          }
  
          if (trailingCall) {
              proxy();
          }
      }
  
      /**
       * Callback invoked after the specified delay. It will further postpone
       * invocation of the original function delegating it to the
       * requestAnimationFrame.
       *
       * @returns {void}
       */
      function timeoutCallback() {
          requestAnimationFrame(resolvePending);
      }
  
      /**
       * Schedules invocation of the original function.
       *
       * @returns {void}
       */
      function proxy() {
          const timeStamp = Date.now();
  
          if (leadingCall) {
              // Reject immediately following calls.
              if (timeStamp - lastCallTime < trailingTimeout) {
                  return;
              }
  
              // Schedule new call to be in invoked when the pending one is resolved.
              // This is important for "transitions" which never actually start
              // immediately so there is a chance that we might miss one if change
              // happens amids the pending invocation.
              trailingCall = true;
          } else {
              leadingCall = true;
              trailingCall = false;
  
              setTimeout(timeoutCallback, delay);
          }
  
          lastCallTime = timeStamp;
      }
  
      return proxy;
  }