在调用外部函数的决心之前履行承诺

时间:2018-03-12 11:59:19

标签: javascript promise addeventlistener

我正在尝试resolve作为事件监听器调用的外部函数中的Promise。问题是,Promise根本不会等待resolve回调。

另外,请记住我需要使用普通ES5的解决方案。

通话:

render(map)
.then(function(road){ return paint(road, map, imgs) })
.then(function(){ asyncListen(keyhandler, ['numeric']) }) //should waiy by user input...
.then(function(r){ console.log('resolved: ' + r) }); //... but this logs undefined before it

asyncListener:

function asyncListen(handler, keys){
    return new Promise(function(resolve, reject){
        var keyhandler = handler.call(this, resolve);
        document.addEventListener("keyup", keyhandler);
        keys.forEach(function(key){ 
            var upperKey = key.toUpperCase();
            var objKey = iAppLib.keys[upperKey];        
            upperKey === 'NUMERIC' ? iAppLib.registerRcuEvent(objKey, keyhandler) : iAppLib.registerRcuEvent(objKey);
        });

        iAppLib.registerAllRcuEvents(function() { return false; });
    });
}

keyhandler:

function keyhandler(resolve){
    return function(num){
        if (num >= 1 && num <= 4){
            resolve(num);
        }   
    }
}

我已经尝试了一些解决方法,比如在Promises中包含de event和keyhandler,但它没有成功。解决方案herehere也是如此。

1 个答案:

答案 0 :(得分:-1)

返回//folderName

asyncListen