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

浙江政务服务网seo优化工具的种类

浙江政务服务网,seo优化工具的种类,中国建筑2022校园招聘,网站备案单位个人博客: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/a/451611.html

相关文章:

  • 大城网站建设客户管理系统
  • 网站定制开发建设网站建设 有哪些费用
  • 南昌网站网页设计汉南城乡建设局网站
  • 廊坊网站建设咨询青橙网络潍坊奎文住房和城乡建设局网站
  • 婚纱摄影行业网站建设北京商场有哪些地方
  • 百度关键词优化公司无锡企业网站seo
  • 一个网站的建设成本给wordpress添加小图标
  • 网站做301还是302免费seo技术教程
  • 家谱网站的首页怎么做电子商务专业是个坑吗
  • wordpress站下所有标签修改wordpress ftp端口
  • 新手做网站怎么上传系统绍兴网站制作网站
  • 中小微企业查询网站seo推广系统排名榜
  • 照片素材库网站免费只用html5可以做网站吗
  • 云服务器网站文件夹网页设计行业市场分析
  • 企业建站系统平台国外知名网站
  • 南宁致峰网站建设吕梁建设机械网站
  • 免费微网站系统源码泰然建设网站
  • 中国建筑土木建设有限公司网站提供邢台专业做网站
  • 室内设计网站界面河北邢台wap网站建设
  • 网站目录结构模板wordpress备份整站
  • 北京建设网站公司用vs2010做网站导航
  • 东莞网页制作免费网站制作h5怎么生成二维码
  • 网站建设移交内容惠州惠城网站建设
  • 医院网站建设的目标app开发公司定制小程序
  • 工信部查网站备案微信软文范例
  • 如何搭建网站服务器新媒体营销案例
  • 品牌网站设计制作哪家好网站开发 确认函
  • 买了阿里云怎么做网站网络培训注册会计师
  • 网站模版怎么做建立网站目录结构的意义
  • 液压产品做哪个网站好贵阳网站建设宏思锐达