javascript - 循环体中,dom 渲染问题
ringa_lee
ringa_lee 2017-04-11 11:17:40
[JavaScript讨论组]
html 块

0

var throttle = function (fn, delay) { var timer = null; var t_start; return function () { var context = this, args = arguments, t_curr = +new Date(); clearTimeout(timer); if (!t_start) { t_start = t_curr; } if (t_curr - t_start >= 166) { fn.apply(context, args); t_start = t_curr; } else { timer = setTimeout(function () { fn.apply(context, args); }, delay); } }; } function jump(elem) { var startNum = $(elem).data("start") ,endNum = $(elem).data("end"); for (; startNum < endNum; startNum++) { requestAnimationFrame((function(startNum){ return throttle(function(){ elem.innerText = startNum; },66) })(startNum)) } }

jump(document.querySelector('.price'));

requestAnimationFrame 中 callback 改写为

        requestAnimationFrame((function (startNum) {
            return function () {
                console.log(startNum);
                elem.innerText = startNum;
            }
        })(startNum))

不能动态修改视图数据,但是startNum 是一直自增的, 为什么需要 函数节流?

ringa_lee
ringa_lee

ringa_lee

全部回复(1)
ringa_lee
timer = setTimeout(function () {
    fn.apply(context, args);
}, delay);

函数节流2个目的:

  • 让一个函数只有在你不断触发后停下来歇会才开始执行,中间你操作得太快它直接无视你。

  • 让一个函数不要执行得太频繁,减少一些过快的调用来节流。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号