• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
四品带砖侍卫
博客园    首页    新随笔    联系   管理    订阅  订阅

手写防抖节流函数

防抖函数

function debounce(fn, t) {
   let timeId
   return function () {
// 如果有定时器就清除
   if (timeId) clearTimeout(timeId)
// 开启定时器 200
   timeId = setTimeout(function () {
     fn()
   }, t)
  }
}
// 节流函数 throttle
function throttle(fn, t) {
// 起始时间
   let startTime = 0
   return function () {
   // 得到当前的时间
   let now = Date.now()
   // 判断如果⼤于等于 500 采取调⽤函数
        if (now - startTime >= t) {
             // 调⽤函数
            fn()
           // 起始的时间 = 现在的时间 写在调⽤函数的下⾯
           startTime = now
         }
   }
}
posted @ 2023-04-12 09:49  四品带砖侍卫  阅读(27)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3