您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關web項目開發中JS函數防抖與節流示例代碼怎么寫,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
經典應用常見: 手風琴效果
沒有做防抖的網站:
做了防抖的網站:
抖動 : 用戶本來不想觸發這個交互,但是由于鼠標不小心抖動誤觸發交互事件。
例子: 想看第五張圖片,。不想看2 3 4張。 但是鼠標從第1張滑到第五張時候,不小心放在了2 3 4上面。誤觸發。
函數防抖 : 用戶連續多次觸發某個事件,則只執行最后一次。
解決原理: 開啟定時器,間隔時間內如果多次觸發事件,則每一次都清除上一次定時器。
實例及解決代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>動畫-案例《手風琴》</title> <style> * { margin: 0; padding: 0; } ul { list-style: none; width: 2400px; } #box { width: 1200px; height: 400px; border: 1px solid red; margin: 100px auto; overflow: hidden; } #box li { width: 100px; height: 400px; float: left; transition: all 0.5s ease-out; } #box li.over { width: 800px; } </style> </head> <body> <div id="box"> <ul> <li v-for="(item,index) in list" :class="{over:overIndex == index}" @mouseenter="doEnter(index)"> <img :src="item" alt=""> </li> </ul> </div> <script src="./vue.js"></script> <script> let app = new Vue({ el:'#box', data:{ overIndex:0, list:[ './images/collapse/1.jpg', './images/collapse/2.jpg', './images/collapse/3.jpg', './images/collapse/4.jpg', './images/collapse/5.jpg', ], timeID:null }, methods: { doEnter(index){ /* 開啟防抖 */ //1.1 先清除上一次定時器,以本次為準 clearTimeout(this.timeID) //1.2 開啟定時器(防抖間隔) this.timeID = setTimeout(()=>{ this.overIndex = index; },500) } }, }) </script> </body> </html>
經典應用場景: 搜索聯想詞
-開發中, 該功能后端會使用中間件"OpenSearch"或者"Elasticsearch", 后端的邏輯處理會十分高效、快捷.
-此處只是基于前端的角度, 從減少http請求這個方面出發來進行優化
<!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>Document</title> </head> <body> <input type="text" placeholder="請輸入搜索內容"> <script> let timeID = null; document.querySelector('input').oninput = function(){ /* 函數防抖 */ //(1)先清除以前的定時器 clearTimeout(timeID) //(2)開啟防抖定時器 timeID = setTimeout(() => { console.log( this.value ); }, 500); } </script> </body> </html>
概念: 解決高頻事件帶來的性能問題;高頻事件: 在頁面中,有些事件觸發頻率非常的高。
例如: 鼠標移動,滾輪事件。
解決原理: 用戶連續多次觸發事件,指定時間內只會觸發一次
實例及解決代碼:
<!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>Document</title> <style> body{ height: 3000px; } </style> </head> <body> <script> let lastTime = null; let i = 1; window.onmousemove = function(){ /* 函數節流 */ //(1)判斷兩次觸發事件的時間間隔 let time = Date.now() if( time - lastTime >= 500 ){ console.log('鼠標移動次數:' + i++); //(2)本次觸發時間作為下一次參考間隔 lastTime = time } } // let j = 1; // window.onscroll = function(){ // //(1)判斷兩次觸發事件的時間間隔 // let time = Date.now() // if( time - lastTime >= 500 ){ // console.log('鼠標滾動次數:' + j++); // //(2)本次觸發時間作為下一次參考間隔 // lastTime = time // } // } </script> </body> </html>
以上就是web項目開發中JS函數防抖與節流示例代碼怎么寫,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。