我在使用 Adobe Brackets 运行 Node.js 服务器时遇到问题。进入实时预览后(URL 为http://localhost:SOMERANDOMPORT/path/to/file.html
),我启动服务器。如果我http://localhost:3000/test
直接在另一个选项卡中输入,它会显示正确的 JSON。
然后,我向一个元素添加了一个事件函数file.html
,在单击它时,它会向我的服务器发出 AJAX 请求,并使用响应来更改它的一些内部 HTML。但是,在实时预览中单击元素会失败,而是调用错误回调。
我怎样才能解决这个问题?我怀疑这与 AJAX 请求发送到http://localhost:SOMERANDOMPORT/test
而不是的事实有关http://localhost:3000/test
,但我似乎找不到解决方案。
一切都在本地运行。下面是我的服务器:
var express = require('express');
var mysql = require('mysql');
var app = express();
app.get('/test', function(req, res){
var connection = mysql.createConnection(...);
connection.query("SELECT author FROM posts", function(err, results) {
if (err) {
console.log(err);
console.log('Error on retrieving data.');
res.send(err);
return;
}
console.log(results[results.length - 1]);
res.send(results[results.length - 1]); // return last row
});
connection.end();
});
app.listen(3000);
console.log('Listening on port ' + port);
和事件功能:
function getAuthor() {
$.ajax({
type: 'GET',
url: '/test',,
success: function(data, status) {
$('.author').text('Authored by ' + data.author);
},
error: function(jqXHR, status, error) { // this always get called
$('.author').text('Something went wrong.');
}
});
}
我很感激任何帮助。