笛卡尔积算法 防抖 节流

举报
拿我格子衫来 发表于 2022/03/18 01:06:27 2022/03/18
【摘要】   var arr = [[1,2,3], ['a','b','c'], ['x','y']] // 笛卡尔积算法 商品sku生成function calcDescartes(arr) { if (arr.length < 2 ) return arr.join('') return arr.reduce((la...

 


  
  1. var arr = [[1,2,3], ['a','b','c'], ['x','y']]
  2. // 笛卡尔积算法 商品sku生成
  3. function calcDescartes(arr) {
  4. if (arr.length < 2 ) return arr.join('')
  5. return arr.reduce((lastItem, currentItem) => {
  6. let res = []
  7. lastItem.forEach(x => {
  8. currentItem.forEach(y => {
  9. res.push(x + '_' + y)
  10. })
  11. })
  12. return res
  13. })
  14. }

防抖:在一定时间内只执行一次

 

节流:每隔一定时间就执行一次


  
  1. // 防抖 在一定时间内只执行一次
  2. function debounce(fn, wait) {
  3. var timeout = null
  4. return function () {
  5. if (timeout !== null) clearTimeout(timeout)
  6. timeout = setTimeout(fn, wait)
  7. }
  8. }

  
  1. // 节流
  2. let throttle = function (func, delay) {
  3. let prev = Date.now()
  4. return function () {
  5. let context = this
  6. let args = arguments
  7. let now = Date.now()
  8. if (now - prev >= delay) {
  9. func.apply(context, args)
  10. prev = Date.now()
  11. }
  12. }
  13. }

 

 

文章来源: fizzz.blog.csdn.net,作者:拿我格子衫来,版权归原作者所有,如需转载,请联系作者。

原文链接:fizzz.blog.csdn.net/article/details/106484035

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。