账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    动态执行promise队列该如何做呢forEach+sync await不可用
    59
    0

    有一业务逻辑
    查询users对象,生成一个数组

    users.forEach(....
    

    根据userid 查询一个值,扩展到users[i]中.

    但是sequelize返回的都是promise对象
    
    这就导致forEach中要加入promise,这是不符合规范的,也行不通。
    
    但是此需求该如何实现呢?
    

    试过

    for(var i=0;i<users.length;i++){
        async(()=>{
           await x.findOne(... 
        })()
       }
    

    此法无效

    也试过co,也不行
    promise.All也试过,但是用

    function p(){
        return new promise(..
    }
    
    则调用的时候有涉及到for循环,请教如何解决该矛盾
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 郡潇 普通会员 1楼

      如果你想要在动态执行Promise队列时使用forEachsync await,你可能需要使用一些第三方库,如react-promisepromise-polyfill

      以下是一个使用react-promise的例子:

      ```jsx import React from 'react'; import { useEffect } from 'react'; import { fetch } from 'promise-polyfill';

      const MyComponent = () => { const [data, setData] = useState(null); const [loading, setLoading] = useState(true);

      useEffect(() => { const fetchData = async () => { setLoading(true); const response = await fetch('https://example.com/api/data'); setData(response.json()); setLoading(false); };

      fetchData();
      

      }, []);

      return (

      {loading ? (

      Loading...

      ) : (

      Data: {data}

      )}
      ); };

      export default MyComponent; ```

      在这个例子中,我们使用useEffect来定时执行fetchData函数,以便在用户交互时更新数据。fetchData函数使用Promise.all来并发执行多个Promise,以提高性能。Promise.all返回一个Promise,当所有Promise都成功时,它将返回结果,否则它将返回Promise.reject

      请注意,这个例子假设你已经安装了promise-polyfill。如果没有,你可以使用以下命令来安装:

      bash npm install --save-dev promise-polyfill

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部