为了账号安全,请及时绑定邮箱和手机立即绑定

js 怎么根据数组内每一项的时长依次执行

js 怎么根据数组内每一项的时长依次执行

慕少森 2018-10-17 17:15:08
var arr = [{        id: 0,        img: '',        music: '',        duration: 2000     }, {        id: 1,        img: '',        music: '',        duration: 4000     }, {        id: 2,        img: '',        music: '',        duration: 6000     }, {        id: 3,        img: '',        music: '',        duration: 3000     }];我有这样的一个数组,每一项有相应的图片、音乐、时长,想要达到根据每一项的duration值依次显示对应项的图片及音乐播放
查看完整描述

1 回答

?
繁华开满天机

TA贡献1816条经验 获得超4个赞

在 ES6 下可以用 Promise 实现

// ES6 Promise 实现function make(m) {    return new Promise(resolve => {        // show(m.img);
        // play(m.music);
        console.log(m);
        setTimeout(resolve, m.duration);
    });
}let p = make(arr[0]);for (let i = 1, len = arr.length; i < len; i++) {
    p = p.then(() => make(arr[i]));
}

用 es7 的 async/await 语法更简洁

(async function() {    for (let i = 0, len = arr.length; i < len; i++) {        const m = arr[i];     
   await new Promise(resolve => {            // show(m.img);
            // play(m.music);
            console.log(m);
            setTimeout(resolve, m.duration);
        });
    }
})();

如果是 es5 呢

可以用第三方 Promise 库,比如 Async.js、Bluebird、jQuery 的 Deferred 等,写法参考第1个


查看完整回答
反对 回复 2018-11-11
  • 1 回答
  • 0 关注
  • 580 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号