所以我正在尝试在 node.js 中制作 Alexa 技能 - 但是,我似乎无法弄清楚如何定义 json 元素。我需要加入所有元素,在本例中它们是来自新闻 API 的标题。我把它们都放在 console.logg'ed 上了,它可以工作,但我需要做的就是弄清楚如何使“title”成为一个变量。我如何使“标题”成为一个变量以包含 JSON 文件中的所有标题。这是我的代码:
var Alexa = require('alexa-sdk');
var request = require('request');
var APP_ID = "amzn1.ask.skill.36267067-d40c-460c-b07b-cc603b97be1b";
var url = "https://newsapi.org/v1/articles?source=googlenews&sortBy=top&apiKey=6e23e1ddb67e40cb93cf147718f18e36";
var handlers = {
'LaunchRequest': function () {
this.emit('NewsIntent');
},
// Get titles from JSON URL & Output it
'NewsIntent': function () {
request({
url: url,
json: true
}, function (error, response, body) {
if (!error && response.statusCode === 200) {
console.log(body.articles[0].title);
console.log(body.articles[1].title);
console.log(body.articles[2].title);
console.log(body.articles[3].title);
console.log(body.articles[4].title);
console.log(body.articles[5].title);
console.log(body.articles[6].title);
console.log(body.articles[7].title);
console.log(body.articles[8].title);
console.log(body.articles[9].title);
///// I need help here!!!!! ---->
/// need to define title, so I can speech emit it below.
this.emit(':tellWithCard', title.join(''));
}
});
}
};
exports.handler = function(event, context, callback) {
var alexa = Alexa.handler(event, context);
alexa.APP_ID = APP_ID;
alexa.registerHandlers(handlers);
alexa.execute();
};
使用
articles
遍历
map
数组然后它们可以稍后加入。
var titles = body.articles.map(function(article) {
return article.title;
});
注意:如果任何标题未定义,将显示在连接中。
更新: 根据您评论中的要点,您可以执行以下操作:
var handlers = {
'LaunchRequest': function() {
this.emit('NewsIntent');
},
// Get titles from JSON URL & Output it
'NewsIntent': function() {
request({
url: url,
json: true
}, function(error, response, body) {
var titles;
if (!error && response.statusCode === 200) {
console.log(body.articles[0].title);
console.log(body.articles[1].title);
console.log(body.articles[2].title);
console.log(body.articles[3].title);
console.log(body.articles[4].title);
console.log(body.articles[5].title);
console.log(body.articles[6].title);
console.log(body.articles[7].title);
console.log(body.articles[8].title);
console.log(body.articles[9].title);
titles = body.articles.map(function(article) {
return article.title;
});
this.emit(':tellWithCard', titles.join(''));
}
});
}
};