我正在使用Twitter API,我遇到了一个非常令人困惑的问题。
我有以下脚本:
const Twitter = require('twitter-api-stream')
const twitterCredentials = require('./credentials').twitter
const twitterApi = new Twitter(twitterCredentials.consumerKey, twitterCredentials.consumerSecret, function(){
console.log(arguments)
})
twitterApi.getUsersTweets('everycolorbot', 1, twitterCredentials.accessToken, twitterCredentials.accessTokenSecret, (error, result) => {
if (error) {
console.error(error)
}
if (result) {
console.log(result) // outputs an array of json objects
console.log(result.length) //outputs 3506 for some reason (it's only an array of 1)
console.log(result[0]) // outputs a opening bracket ('[')
console.log(result[0].text) // outputs undefined
}
})
调用以下函数与twitter进行交互:
TwitterApi.prototype.getUsersTweets = function (screenName, statusCount, userAccessToken, userRefreshToken,cb ) {
var count = statusCount || 10;
var screenName = screenName || "";
_oauth.get(
"https://api.twitter.com/1.1/statuses/user_timeline.json?count=" + count + "&screen_name=" + screenName
, userAccessToken
, userRefreshToken
, cb
);
};
似乎就像我得到了我想要的结果。当我记录结果本身时,我得到以下输出:
[
{
"created_at": "Thu Sep 01 13:31:23 +0000 2016",
"id": 771339671632838656,
"id_str": "771339671632838656",
"text": "0xe07732",
"truncated": false,
...
}
]
这很棒,推文的数组仅限于1条推文。
我遇到的问题是当我尝试访问此数组时。
console.log(result.length) //outputs 3506 for some reason (it's only an array of 1)
console.log(result[0]) // outputs a opening bracket ('[')
console.log(result[0].text) // outputs undefined
我通过api docs for the user_timeline回读,但除非我完全错过它,否则我没有看到任何特殊输出。
有什么想法吗?
感谢@nicematt指出答案。
为了详细说明解决方案,我将代码更新为此,现在我得到了我想要的结果:
if (result) {
let tweet = JSON.parse(result)[0] // parses the json and returns the first index
console.log(tweet.text) // outputs '0xe07732'
}
感谢您的帮助!
答案 0 :(得分:16)
结果是String
并且您正在为其编制索引(result[0]
(而0
转换为字符串),尽管几乎与result.charAt(0)
相同,这就是result[0]
等于"["
的原因 - 因为它是指定的第一个字符。你忘了将结果解析为JSON数据。
JSON.parse(result).length // probably 1
而且result.text
是undefined
,因为result
(一个字符串)就像一个Object
(但不是实例)并且允许查找和getter发生在本身。
我也显示了str[0]
和str.charAt(0)
之间的区别:
str[0] // same as str['0'], but a getter. 0 converts to
// string (because every key of an object
// is string in ECMAScript)
str.charAt(0) // get/lookup String#charAt, call it
// without new `this` context and with arguments list: 0