91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

web項目開發中JS函數防抖與節流示例代碼怎么寫

發布時間:2021-09-24 16:34:25 來源:億速云 閱讀:109 作者:柒染 欄目:開發技術

本篇文章給大家分享的是有關web項目開發中JS函數防抖與節流示例代碼怎么寫,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

    防抖

    經典應用常見: 手風琴效果

    引入

    沒有做防抖的網站:

    web項目開發中JS函數防抖與節流示例代碼怎么寫

    做了防抖的網站:

    web項目開發中JS函數防抖與節流示例代碼怎么寫 

    防抖場景1(鼠標移入)

    抖動 : 用戶本來不想觸發這個交互,但是由于鼠標不小心抖動誤觸發交互事件。
    例子: 想看第五張圖片,。不想看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>

    防抖場景2(鍵盤按鍵)

    經典應用場景: 搜索聯想詞
    -開發中, 該功能后端會使用中間件"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函數防抖與節流示例代碼怎么寫,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    勃利县| 通海县| 广水市| 乃东县| 苍南县| 宁陵县| 深州市| 鄂温| 双牌县| 长顺县| 阿拉善左旗| 高青县| 上饶县| 静宁县| 开化县| 云安县| 满城县| 浦东新区| 柯坪县| 抚远县| 福安市| 夹江县| 静海县| 和龙市| 吉木乃县| 泉州市| 阳新县| 会同县| 阳春市| 长汀县| 怀安县| 高清| 青浦区| 文安县| 金沙县| 六盘水市| 长寿区| 东阳市| 绥芬河市| 内丘县| 赫章县|