我试图从php文件中查询数据库,然后将结果(每行的userLOC)返回给调用的Jquery函数。
调用Jquery:
$.post(url, data, function (data)
{
alert(data);
})
放松PHP:
$sql = "Select * from location";
$result = mysql_query($sql);
$stack = array();
while($row = mysql_fetch_array($result))
{
array_push($stack, $row["userLOC"]);
}
return $stack;
问题是,我不能正确地返回它,如果我“回显$stack”它不工作,它说我试图把数组转换成字符串。如果我“回显$stack”,它将给出数组中的第一个结果,这样我就知道值被正确地存储了(就像$stack1,等等)。但这只会将一个值发回。如果我“返回$stack”,如图所示,没有任何警报,因为什么都没有回音。我将如何返回整个数组,以便迭代并在jquery端使用它们?
发布于 2013-10-15 12:54:59
在PHP中
$foo = array();
echo $foo;
将产生文字字符串Array
作为输出。
您需要将数组转换为字符串。由于您处理的是Javascript目标,因此使用JSON作为实现此目标的最佳方法:
$foo = array('a', 'b', 'c', 'd', 'e');
echo json_encode($foo);
然后在您的JS代码中:
$.get(...., function (data) {
alert(data[1]); // spits out 'b'
});
只需记住告诉jquery您正在期待JSON输出。
发布于 2013-10-15 12:55:03
您需要以一种可以通过HTTP传输到客户端并用于获取原始数据的方式包装(序列化)数据。通常的容器格式是XML和JSON。JSON非常适合在JavaScript中使用,所以使用json_encode()函数并回显结果。
发布于 2013-10-15 12:58:56
您将希望使用JSON!
客户端:
jQuery.post(url, data, function( data ) {
//Data is already converted from JSON
}, "json");
服务器端:
return json_encode($stack);
希望这能有所帮助!
https://stackoverflow.com/questions/19390829
复制