连续点击触发方法,比如树形结构,希望事件执行一次

直接示例jQuery(window).on('resize',calculateLayout);
这里的事件在resize发生时会不停的触发,那么怎么优化使的该事件在最后停止的时候只触发一次呢,如下jQuery(window).on('resize', _.debounce(calculateLayout, 150)),使用lodashdebounce方法,通常用的过滤方法中,比如你有一个树形结构,里面是人员,你选中人员后人员在另一个展示面板展示出来,如果你有1w天数据,那么你手动选中的话,那过滤可想而知了,但用了该方法后,可以优化很多性能。
顺便介绍一个它的兄弟throttle
直接看代码jQuery(window).on('scroll', _.throttle(updatePosition, 100));
这里是频率触发的,就像钟表,每秒走一下,也就是说在滚动事件里,本事无数个触发,在用了之后呢,只会隔断事件触发一下
总而言之,这两个方法都是用于减少事件的触发次数,具体用哪个看你自己的需要。
备注:个人理解,如有错误请指正

猜你喜欢

转载自blog.csdn.net/qq_43702430/article/details/86571127