Javascript - 创建新数组而不是递增

时间:2016-01-23 17:37:04

标签: javascript

我制作一个简单的Twitter应用程序来处理我的javascript。 下面的代码应该识别每个推文的位置,并计算每个位置的推文数量。

但是,它不会增加,只会创建一个新数组。 我的代码出了什么问题?我怎样才能让它变得更好?

谢谢

var Twitter = require('node-twitter'),
twit = {},
loc = [];

twit.count = 0;


var twitterStreamClient = new Twitter.StreamClient(
//credentials
);

twitterStreamClient.on('close', function () {
    console.log('Connection closed.');
});
twitterStreamClient.on('end', function () {
    console.log('End of Line.');
});
twitterStreamClient.on('error', function (error) {
    console.log('Error: ' + (error.code ? error.code + ' ' + error.message : error.message));
});
twitterStreamClient.on('tweet', function (tweet) {


    if (loc.indexOf(tweet.user.location) === -1) {
        loc.push({"location": tweet.user.location, "locCount": 1});
    } else {
        loc.loation.locCount = loc.loation.locCount + 1;
    }


    console.log(loc);

});

var search = twitterStreamClient.start(['snow']);

2 个答案:

答案 0 :(得分:2)

您需要重写on tweet回调:

var index = loc.reduce(function(acc, current, curIndex) {
   return current.location == tweet.user.location ? curIndex : acc;
}, -1);

if (index === -1) {
    loc.push({"location": tweet.user.location, "locCount": 1});
} else {
    loc[index].locCount++;
}

答案 1 :(得分:0)

Array.indexOf与您认为不匹配。您正在创建一个新对象并将其推入数组中,无论其属性是否与其他对象完美匹配,它都不会===相等。相反,你必须手动找到它:

var foundLoc;
for (var i = 0; i < loc.length; i++) {
  if (loc[i].location.x === location.x) 
     foundLoc = loc[i];
     break;
  }
}
if (!foundLoc) { 
  loc.push({location: location, count: 0});
} else {
  foundLoc.count++
}
相关问题