函數防抖

来源:https://www.cnblogs.com/ywnh/archive/2020/02/20/12314022.html
-Advertisement-
Play Games

概述:"一個處理函數會在延遲n秒後觸發,如果在n秒內再次觸發那麼回重新計時; 優點:防止用戶由於過快的操作而發起的無用的請求; 使用場景: 1、淘寶的導航列表; 2、搜索框搜索輸入。只需用戶最後一次輸入完成,在發送請求; 3、瀏覽器的視窗大小改變後,只需視窗調整完成後,在執行 裡面是代碼,防止重新渲 ...


概述:"一個處理函數會在延遲n秒後觸發,如果在n秒內再次觸發那麼回重新計時;

<script>
    var throttle = function(func, delay) {
      // 存儲定時器id;
      var timer = null
      return function() {
        // 判斷定時器是否在執行中;
        if (timer) {
          // 在每次開始之前清除以前的定時器;
          clearTimeout(timer)
        }
        timer = setTimeout(function() {
          func()
        }, delay)
      }
    }
    // 要進行處理的函數;
    function handle() {
      console.log(Math.random())
    }
    window.addEventListener('mousemove', throttle(handle, 1000))
  </script>

優點:防止用戶由於過快的操作而發起的無用的請求;

使用場景:

1、淘寶的導航列表;

2、搜索框搜索輸入。只需用戶最後一次輸入完成,在發送請求;

3、瀏覽器的視窗大小改變後,只需視窗調整完成後,在執行resize裡面是代碼,防止重新渲染;


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 顧名思義 zookeeper 就是動物園管理員,他是用來管 hadoop(大象)、Hive(蜜蜂)、pig(小 豬)的管理員, Apache Hbase 和 Apache Solr 的分散式集群都用到了 zookeeper;Zookeeper: 是一個分散式的、開源的程式協調服務,是 hadoop ...
  • 主要用到的Zookeeper機制: 臨時+有序節點,節點watch機制 過程: 1. 發生分散式鎖競爭時,參與競爭的各個客戶端服務都到Zookeeper的同一父節點(代表著同一把鎖)下建立自己的臨時+有序子節點,創建成功後子節點名被zk返回給客戶端,各客戶端保存在本地。 2. 所有客戶端服務都拉取父 ...
  • Android中一個用於網頁顯示的控制項,實際上,也可以看做一個功能最小化的瀏覽器,看起來類似於在微信中打開網頁鏈接的頁面。WebView主要用於在app應用中方便地訪問遠程網頁或本地html資源。同時,WebView也在Android中充當Java代碼和JS代碼之間交互的橋梁。 WebView基本用 ...
  • 解決方法一: 前提:需要一個鍵盤 步驟: 1、直接按下鍵盤上的Menu鍵。 解決方法二: 前提:需要Root之後的文件瀏覽器 步驟: 1、在文件管理器中打開 /System 文件夾; 2、複製 build.prop 文件到 SD Card 文件夾,並將原始的 build.prop 重命名備份; 3、 ...
  • 講述面向對象中的一個重要概念——繼承,使用繼承 可以方便地在已有類的基礎上進行擴展,定義一個具有父 類全部功能的新類。 父類和子類 我們在定義一個新類的時候,經常會遇到要定義的新類是某個類的擴展或者是對某個類的修正 這種情況。如果可以在已有類的基礎上追加內容來定義新類,那麼新類的定義將會變得更簡單。 ...
  • 完整代碼下載: 百度網盤地址 https://pan.baidu.com/s/1qFsRoODkccF1VkEsGLsQTw 提取碼 :p4zr 永久有效 有疑問可以給我發郵件:[email protected] || [email protected] 1 註冊頁面 2 登錄頁面 3 登錄成功主 ...
  • 可以用jQuery中的unbind()來進行事件解綁。 1 $(window).scroll(function() { 2 console.log("滾離頂部" + $(document).scrollTop()); 3 4 //... 5 6 //對window對象進行scroll事件解綁 7 $ ...
  • Callback hell回調地域 當我們以同步的方式編寫耗時的代碼,那麼就會阻塞JS的單線程,造成CPU一直等待IO完成才去執行後面的代碼。 而CPU的執行速度是遠遠大於硬碟IO速度的,這樣等待只會造成資源的浪費。 非同步IO就是為瞭解決這個問題的,非同步能儘可能不讓CPU閑著,它不會在那等著IO完成 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...