乾坤框架中reduce的巧妙使用

JavaScript中,reduce是一个数组方法,用于将数组中的元素按照指定的方式进行累积计算。它接受一个回调函数作为参数,并且可以接受一个初始值作为可选参数。 回调函数接受四个参数:累积值(也称为累加器)、当前值、当前索引和原始数组。回调函数应该返回一个新的累积值,该值将在下一次迭代中作为累积值传递。

csharp 复制代码
const numbers = [1, 2, 3, 4, 5];

const sum = numbers.reduce((accumulator, currentValue) => {
  return accumulator + currentValue;
}, 0);

console.log(sum); // 输出 15

在乾坤框架中有一个很有意思的reduce的使用

csharp 复制代码
function execHooksChain<T extends ObjectType>(
  hooks: Array<LifeCycleFn<T>>,
  app: LoadableApp<T>,
  global = window,
): Promise<any> {
  if (hooks.length) {
    return hooks.reduce((chain, hook) => chain.then(() => hook(app, global)), Promise.resolve());
  }

  return Promise.resolve();
}

这段代码使用了reduce 方法来依次执行一个包含多个异步操作的数组hooks 。每个异步操作都是一个函数,接受两个参数appglobal,并返回一个Promise。

  1. hooks是一个包含多个异步操作的数组。
  2. reduce 方法被调用在hooks 数组上,初始值为Promise.resolve() ,这是一个已经解决(resolved)的Promise
  3. 在每次迭代中,reduce 方法将累积值chain 和当前值hook作为参数传递给回调函数。
  4. 回调函数中,chain 是一个Promise,表示前面所有异步操作的链式调用。hook是当前的异步操作函数。
  5. 回调函数中,**chain.then(() => hook(app, global))**将当前异步操作函数添加到前面所有异步操作的链式调用中。这样可以确保前一个异步操作完成后再执行下一个异步操作。
  6. reduce方法返回的是一个Promise,表示所有异步操作的链式调用。
  7. 最后,这个Promise可以被进一步处理,例如使用**.then()**方法添加回调函数来处理所有异步操作完成后的结果。

这段代码的目的是按照数组中的顺序依次执行异步操作,并确保每个异步操作在前一个操作完成后再执行。这种方式可以用于处理需要按顺序执行的异步任务,例如在应用程序初始化过程中加载插件或模块。

html 复制代码
function a() {
        return Promise.resolve();
      }

      function b() {
        return new Promise((resolve, reject) => {
          setTimeout(() => {
            console.log("b");
            resolve(2);
          }, 2000);
        });
      }

      function c() {
        return new Promise((resolve, reject) => {
          setTimeout(() => {
            console.log("c");
            resolve(2);
          }, 2000);
        });
      }

      async function execHooks(funArr) {
        for (let i = 0; i < funArr.length; i++) {
          await funArr[i]();
        }
      }

      function awaitExecHooks(funArr) {
        return funArr.reduce(
          (prev, hook) => prev.then(() => hook()),
          Promise.resolve()
        );
      }
      execHooks([a, b, c]).then(() => {
        console.log("finish");
      });

      var d = awaitExecHooks([a, b, c]);
      d.then(() => {
        console.log("await finish");
      });

同样,使用for循环和await可以实现reduce的效果。reduce是一个很有意思的函数,可以实现一些数组去重,扁平化,数组数据的各种处理。让人想起了RXJS中的scan操作符!

相关推荐
速易达网络32 分钟前
Bootstrap 5 响应式网站首页模板
前端·bootstrap·html
etsuyou34 分钟前
js前端this指向规则
开发语言·前端·javascript
lichong95134 分钟前
Android studio 修改包名
android·java·前端·ide·android studio·大前端·大前端++
cai_huaer35 分钟前
BugKu Web渗透之 cookiesWEB
前端·web安全
lichong95137 分钟前
Git 检出到HEAD 再修改提交commit 会消失解决方案
java·前端·git·python·github·大前端·大前端++
友友马1 小时前
『 QT 』QT控件属性全解析 (一)
开发语言·前端·qt
不想上班只想要钱2 小时前
vue3+vite创建的项目,运行后没有 Network地址
前端·javascript·vue.js
流***陌2 小时前
手办盲盒抽赏小程序前端功能设计:兼顾收藏需求与抽赏乐趣
前端·小程序
岁月宁静2 小时前
在富文本编辑器中封装实用的 AI 写作助手功能
前端·vue.js·人工智能
金士顿2 小时前
为什么MainWindow.xaml绑定的datacontext,EtherCATSuiteCtrl.xaml直接用了?
前端