I am making an API request and would like to ask the user a question with the data returned from the request. I make a call to a function, which executes the request and returns the appropriate response:
httpRequest(params).then(function(body) {
console.log(body);
this.emit(':ask', speechOutput, repromptSpeech);
});
The this.emit function returns an unhandled promise rejection error. How can I wait for the request callback to be executed and then issue the :ask event?
The this
inside the promise handler isn't the same as this
outside of it, so I think the unhandled promise rejection might have stated that this.emit
isn't a function.
A quick solution would be to use an arrow function , which is probably why the code in your own answer works too:
// `this` here...
httpRequest(params).then(body => {
console.log(body);
this.emit(':ask', speechOutput, repromptSpeech); // ...is the same as `this` here
}).catch(error => {
console.error('uh-oh!', error);
});
I ended up solving this using the request library:
function getEntries() {
return request.get('https://wezift.com/parent-portal/api/entries.json');
}
getEntries().then(
(response) => {
console.log(response);
this.emit(':ask', 'hi', 'hi again');
},
(error) => {
console.error('uh-oh! ' + error);
}
);
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.