JS的函数节流使用

这次给大家带来js的函数节流使用,js函数节流使用的注意事项有哪些,下面就是实战案例,一起来看一下。

函数节流(throttle)

函数节流就是预定一个函数只有在大于等于执行周期时才执行,周期内调用不执行。好像水滴攒到一定重量才会落下一样。

场景:

窗口调整(resize)

页面滚动(scroll)

抢购疯狂点击(mousedown)

实现:

function throttle(method, delay){    var last = 0;    return function (){        var now = +new Date();        if(now - last > delay){            method.apply(this,arguments);            last = now;        }    }}document.getElementById('throttle').onclick = throttle(function(){console.log('click')},2000);

登录后复制

underscore实现:

_.throttle = function(func, wait, options) {    var context, args, result;    var timeout = null;    var previous = 0;    if (!options) options = {};    var later = function() {        previous = options.leading === false ? 0 : _.now();        timeout = null;        result = func.apply(context, args);        if (!timeout) context = args = null;    };    return function() {        var now = _.now();        if (!previous && options.leading === false) previous = now;        //计算剩余时间        var remaining = wait - (now - previous);        context = this;        args = arguments;        //剩余时间小于等于0或者剩余时间大于等待时间(本地时间变动出现)        if (remaining  wait) {            if (timeout) {                clearTimeout(timeout);                timeout = null;            }            previous = now;            result = func.apply(context, args);            if (!timeout) context = args = null;        } else if (!timeout && options.trailing !== false) {            timeout = setTimeout(later, remaining);        }        return result;    };};

登录后复制

函数防抖(debounce)

函数防抖就是在函数需要频繁触发情况时,只有足够空闲的时间,才执行一次。好像公交司机会等人都上车后才出站一样。

场景:

实时搜索(keyup)

拖拽(mousemove)

实现:

function debounce(method, delay){    var timer = null;    return function(){        var context = this,args = arguments;        clearTimeout(timer);        timer = setTimeout(function(){            method.apply(context, args);        },delay);    }}document.getElementById('debounce').onclick = debounce(function(){console.log('click')},2000);

登录后复制

underscore实现:

_.debounce = function(func, wait, immediate) {    var timeout, args, context, timestamp, result;    var later = function() {        var last = _.now() - timestamp;        if (last = 0) {            timeout = setTimeout(later, wait - last);        } else {            timeout = null;            if (!immediate) {                result = func.apply(context, args);                if (!timeout) context = args = null;            }        }    };    return function() {        context = this;        args = arguments;        timestamp = _.now();        var callNow = immediate && !timeout;        if (!timeout) timeout = setTimeout(later, wait);        if (callNow) {            result = func.apply(context, args);            context = args = null;        }        return result;    };};

登录后复制

函数节流(throttle)和函数防抖(debounce)都是通过延时逻辑操作来提升性能的方法,在前端优化中是常见且重要的解决方式。可以从概念和实际应用中理解两者的区别,在需要的时候选择合适的方法处理。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

用JS代码做出弹幕效果

用H5的canvas做出弹幕效果

以上就是JS的函数节流使用的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2783213.html

(0)
上一篇 2025年3月8日 16:46:15
下一篇 2025年3月8日 16:46:20

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解js在html中的加载执行顺序

    js在html中的加载执行顺序 1.加载顺序:引入标记的出现顺序, 页面上的js代码是js的一部分,所以Javascript在页面装载时执行的顺序就是其引入标记的出现顺序, 标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执…

    编程技术 2025年4月4日
    100
  • HTML和JS实现简单的计算器

    HTML和JS实现计算器功能的也是很容易的,本文主要和大家分享HTML和JS实现简单的计算器,希望能帮助到大家。 下面是代码:    nbsp;html>无标题文档 var result=””; function jisuan(num…

    编程技术 2025年4月4日
    100
  • 实现在HTML页面加载完毕后运行js方法

    本文主要和大家分享实现在HTML页面加载完毕后运行js方法,主要以代码的方法和大家分享,希望能帮助到大家。 Js方法: window.onload=function (){ var userName=”xiaoming”; alert(us…

    编程技术 2025年4月4日
    100
  • JavaScript实现获取远程的html到当前页面中

    今天做个项目,需要在当前的html页面中引用一个远程的html页面,百度了一下,发现一个非常好用的代码,这里分享给大家,有相同需求的小伙伴可以来看看 html代码 登录后复制 立即学习“Java免费学习笔记(深入)”; javascript…

    编程技术 2025年4月4日
    200
  • JavaScript模块优化

    给大家分享一下如何才能开发出更好的javascript模块和功能,有兴趣的朋友参考学习下吧。 不少人都曾经在 npm 上发布过自己开发的 JavaScript 模块,而在使用一些模块的过程中,我经常产生“这个模块很有用,但如果能 xxx 就…

    编程技术 2025年4月4日
    100
  • 如何使用Hyperf框架进行日志记录

    如何使用Hyperf框架进行日志记录 引言:在软件开发中,日志记录是一个非常重要的功能,它能够帮助开发人员追踪错误、分析问题以及监控系统运行状态。在使用Hyperf框架进行开发时,我们可以利用其内置的日志组件来实现灵活的日志记录功能。本文将…

    2025年4月2日
    100
  • 如何使用Hyperf框架进行表单验证

    如何使用Hyperf框架进行表单验证 引言:随着Web应用程序的发展,表单验证成为了保证数据的准确性和安全性的重要环节。Hyperf框架作为一款高性能的PHP开发框架,提供了强大的表单验证功能,本文将介绍如何使用Hyperf框架进行表单验证…

    2025年4月2日
    300
  • 如何使用Hyperf框架进行微信支付

    使用Hyperf框架进行微信支付 引言:随着电子商务的发展,微信支付成为了人们日常购物、付款的主要方式之一。在开发中,如何快速集成微信支付变得尤为重要。本文将介绍如何使用Hyperf框架进行微信支付,并提供具体的代码示例。 正文: 一、准备…

    2025年4月2日
    200
  • 如何使用Hyperf框架进行跨库查询

    如何使用Hyperf框架进行跨库查询 引言:随着应用程序的发展,我们往往需要在多个数据库之间进行查询。例如,在一个电商应用中,我们可能需要查询商品信息(存储在一个数据库中)和用户信息(存储在另一个数据库中)。而在使用Hyperf框架开发应用…

    2025年4月2日
    200
  • 如何使用Hyperf框架进行密码重置

    如何使用Hyperf框架进行密码重置 导语:密码重置是网站或应用中常见的功能之一,当用户忘记自己的密码或者需要更改密码时,通过重置密码功能可以方便用户重新设置新密码。本文将介绍如何使用Hyperf框架实现密码重置功能,并提供代码示例。 一、…

    2025年4月2日
    200

发表回复

登录后才能评论