当前位置: 首页 > wzjs >正文

免费网站制作推广莘县网站制作

免费网站制作推广,莘县网站制作,app小程序软件定制开发,衡阳县专业做淘宝网站个人博客:haichenyi.com。感谢关注 一. 目录 一–目录二–防抖三–节流四–进阶应用五–总结 二. 防抖(Debounce) 防抖(Debebounce)和节流(Throttle)都是前端开发中用于优化高频事件性能的两…

个人博客:haichenyi.com。感谢关注

一. 目录

  • 一–目录
  • 二–防抖
  • 三–节流
  • 四–进阶应用
  • 五–总结

二. 防抖(Debounce)

  防抖(Debebounce)和节流(Throttle)都是前端开发中用于优化高频事件性能的两种技术。他们的核心目的是减少函数的不必要的调用频率,但实现方式和场景有所不同。
  原理: 事件触发后,开始计时,若在规定时间内,没有再触发该事件,则执行事件。若在规定时间内,又触发了该事件,则重新计时。
  适用场景: 输入框的搜索事件,窗口大小调整,按钮的点击事件等等

function debounce(func, delay) {let timer;return function (...args) {//清空上一次的定时器clearTimeout(timer)timer = setTimeout(() => {//绑定this关键字和参数,并立即执行//apply,call,bind三者的区别,前面的博客中讲过了func.apply(this, args)}, delay);}
}// 使用示例
const searchInput = document.getElementById('search');
searchInput.addEventListener('input', debounce(function() {console.log('发起搜索请求');
}, 500));

  特点:

  • 高频操作停止后才会执行
  • 若高频操作不停止,则该事件永远不会执行

三. 节流(Throttle)

  原理: 在规定时间间隔内,不论事件触发多少次,函数只会执行一次。
  适用场景​​: 滚动事件(scroll)、鼠标移动(mousemove)、游戏中的射击频率限制等。

function throttle(func, delay) {let lastTime;return function (...args) {let now = Date.now()if (now - lastTime >= delay) {func.apply(this, args)lastTime = now}}
}// 使用示例
window.addEventListener('scroll', throttle(function() {console.log('处理滚动事件');
}, 200));

  特点:

  • 不管事件触发多少次,都按照固定频率执行,稀释执行的次数。
  • 保证高频操作下函数周期性执行。

四. 进阶应用

(4.1)立即执行的防抖,第一次触发立即执行,后续触发防抖:

function debounce(func, delay) {let timer;return function (...args) {//如果timer是空,则立刻执行let immediately = !timer//第一次调用timer就是空,则立刻执行,短时间内再次触发,清空上一次的定时器,clearTimeout(timer)if (immediately) {func.apply(this, args)}timer = setTimeout(() => {timer = null}, delay);}
}

(4.2)头节流(Leading)​:期望第一次触发立即执行

function throttle(func, delay) {let lastTime = 0;return function (...args) {let now = Date.now()// 计算剩余时间(若首次触发则剩余时间 <= 0)let remaining = delay - (now - lastTime)if (remaining <= 0) {func.apply(this, args)lastTime = now}}
}

(4.3)尾节流(Trailing):保证最后一次触发,逻辑会执行

function throttle(func, delay) {let timer = null;return function (...args) {if (!timer) {timer = setTimeout(() => {func.apply(this, args)timer = null}, delay);}}
}

五. 总结

特性​防抖​节流​
执行时机​高频事件结束后,规定时间内执行高频事件按照频率执行
适用场景​输入框,提交按钮等滑动事件,动画渲染
极端情况​持续触发,不会执行持续触发时,函数按规律执行

​防抖​​: 合并多次操作为一次,适合“最终状态”场景(如输入停止后搜索)。
​​节流​​: 稀释执行频率,适合持续高频事件(如滚动事件)。

推荐使用Lodash的方法,不需要自己手动去写,了解防抖节流的原理即可。

http://www.dtcms.com/wzjs/558242.html

相关文章:

  • 下载建设银行官方网站下载人人商城源码
  • 指数网站网络营销论文摘要
  • 个人网站优秀推广策略和推广方法
  • 郑州网站建设 新浪博客怎么用python做网页
  • 网站建设方案书设计图电商网站开发面试题
  • 奢做品二手 哪个网站好国家企业信息管理系统官网
  • 企业进行网站建设的方式wordpress方向
  • 米各庄网站建设太原做手机网站
  • 微信公众号直接同步到wordpress网站seo分析案例
  • 河南网站建设技术公司菠菜网站的代理怎么做的
  • 网站风格的设计原则可以放友情链接的网站
  • 做考勤的网站电子商务网站建设技术规范
  • 动易网站后台编辑器无效问题网站制作中搜索栏怎么做
  • 苏州建设工程人才招聘网信息网站网站空间付款方式
  • 中山网站建设怎么样最新新闻国际新闻
  • 常平东莞网站建设网站做权重的好处
  • 潍坊网站建设一品网络小程序郴州seo快速排名
  • seo做网站赚钱吗网站建设合同黑客攻击
  • 个人做网站费用自己做的网页发布
  • 抚顺营销型网站建设深圳市保障性住房轮候申请系统
  • 免费注册域名网站知乎高端自适应网站开发
  • 网站建站免费江西省城市建设档案馆网站
  • 网站硬件建设方案罗湖田贝社区网站建设
  • 扬州大学第四届网站建设评比做网站要用编程吗
  • 迅捷流程图在线制作网站有哪些好的建站平台
  • 公司网站主页怎么做响应式布局方案
  • 理解电子商务网站建设与管理网站编程语言哪个好
  • 网站建设经典教材wordpress 页面评论
  • 免费vip电影网站怎么做网站开发 jsp
  • 江苏五星建设网站淘宝客如何做网站