2017-10-20 76 views
0

我有这样的代码:服务工作者promise.then没有定义

self.addEventListener('fetch', function(event) { 
const promiseChain = doSomethingAsync() 
     .then(() => doSomethingAsyncThatReturnsAURL(event)) 
     .then(someUrl => fetch(someUrl)); 
event.respondWith(promiseChain); 
}); 

它不断给我这个错误:

Uncaught TypeError: Cannot read property 'then' of undefined

它捡起来,在这条线:

.then(() => doSomethingAsyncThatReturnsAURL(event))

仅供参考:

这里是功能doSomethingAsyncThatReturnsAURL:

function doSomethingAsyncThatReturnsAURL(event) { 
    var location = self.location; 

    console.log("loc", location) 

    self.clients.matchAll({includeUncontrolled: true}).then(clients => { 
    for (const client of clients) { 
     const clientUrl = new URL(client.url); 
     console.log("SO", clientUrl); 
     if(clientUrl.searchParams.get("url") != undefined && clientUrl.searchParams.get("url") != '') { 
     location = client.url; 
     } 
    } 

    console.log("loc2", location) 

    var url = new URL(location).searchParams.get('url').toString(); 

    console.log(event.request.hostname); 
    var toRequest = event.request.url; 
    console.log("Req:", toRequest); 

    var parser2 = new URL(location); 
    var parser3 = new URL(url); 

    var parser = new URL(toRequest); 

    console.log("if",parser.host,parser2.host,parser.host === parser2.host); 
    if(parser.host === parser2.host) { 
    toRequest = toRequest.replace('https://booligoosh.github.io',parser3.protocol + '//' + parser3.host); 
    console.log("ifdone",toRequest); 
    } 

    console.log("toRequest:",toRequest); 

    var finalResult = 'https://cors-anywhere.herokuapp.com/' + toRequest; 

    return finalResult; 

    }); 
} 

而且doSomethingAsync功能:

function doSomethingAsync() { 
     console.log("ASYNC LOL"); 
} 

回答

1

无法读取属性‘然后’未定义”告诉你doSomethingAsync()通话不then属性返回一个对象。我会说doSomethingAsync必须返回Promise。 Promise对象的原型(MDN)上有then方法,因此您可以调用它。试试这个

function doSomethingAsync() { 
    return new Promise(resolve => { 
    console.log("ASYNC LOL"); 
    resolve(); 
    }) 
} 

或只是

function doSomethingAsync() { 
    console.log("ASYNC LOL"); 
    return Promise.resolve(); 
}