我是node.js和json的新手,并且无法将JSON对象返回到使用$.getjson
的客户端html页面。
在下面的示例中,当我在api.twitter ... url指向相同的代码时,我可以查询并返回该值。但是,当我将此指向我自己的node.js后端时,即吐出相同的JSON,alert('inside callback: ' + data[0].is_translator);
不会弹出。我在这做错了什么?我真的很感激这里的一些帮助。
这是我的test.html中的脚本代码,它调用$ .getJSON。
<script>
//var url = "http://localhost:5000/searchPlaces?callback=?";
function abc(result) {
//var url = "http://localhost:5000/random"
var url = "http://api.twitter.com/1/statuses/21947795900469248/retweeted_by.json?callback=?";
alert('before $.getjson');
$.getJSON(url, function(data) {
alert('hello');
alert('inside callback: ' + data[0].is_translator);
abc(result.data);
})
}
abc();
</script>
这是我的node.js后端的代码:
var http = require("http");
var url = require("url");
var port = process.env.PORT || 8888
function start(route, handle){
function onRequest(request, response) {
var postData = "";
var pathname = url.parse(request.url).pathname;
console.log("Request received for:" + pathname + " receieved.");
response.writeHead(200, {"Content-Type": "application/json"});
var otherObject = {"is_translator":false,"id":644233,"followers_count":77};
response.write(
JSON.stringify({
anObject: otherObject
})
);
response.end();
// route(handle, pathname, response, request);
}
http.createServer(onRequest).listen(port);
console.log("Server had started. Port:" + port);
}
exports.start = start;
答案 0 :(得分:0)
仅当JSON有效时才会调用$.getJSON()
的回调。你的twitter api http://api.twitter.com/1/statuses/21947795900469248/retweeted_by.json?callback=?
的url在JSONlint.org上给出了一个带有以下错误的JSON
Parse error on line 1:
([ { "is
^
Expecting '{', '['
你应该使用$ .get()url,然后在使用之前自己验证JSON。