我尝试将字符串解析为jquery对象,但我没有以正确的格式获取它。不知道错误在哪里。 我的目标是从数据库加载数据并将其放入对话框中,我可以在其中更新用户
我的js文件中有一个帖子请求,按下按钮执行:
$.post("index.php", { "id": ID , "action": "edit_row"},
function(input){
console.log(input); //{"id":"1","fname":"Test","lname":"Name"}
console.log(input.id); //undefined
var data = $.parseJSON(input); //Uncaught SyntaxError: Unexpected token
console.log(data); //not possible
console.log(data.id); //not possible
test = {"id":"1","fname":"Test","lname":"Name"};
console.log(test); // I get the object
console.log(test.id); //1
}); // when I use ',"json"' between the brackets nothing happens, no logs are written in console
我的index.php抛出从数据库加载的字符串:
$query = "SELECT `id`, `fname` , `lname` FROM `user` WHERE `id`= ".$id; //it's just one row
$result = sql_query($query);
while ($row= mysql_fetch_assoc($result)){
$data = $row;
};
echo json_encode($data);
//php function
function sql_query($query){
$result = mysql_query($query);
if(!$result) {
die("Request Failed: " . mysql_error());
}
return $result;
}
我分析了js文件中的字符串响应我发现字符串格式为\ r \ n \ r \ n \ r \ n到最后。即使我没有回复php文件中的任何内容......
我认为在处理ajax请求时,我的index.php中存在某些损坏。
我在不同的php文件上做了请求,并且没有任何问题。
$.post("test.php", { "id": ID , "action": "edit_row"},
function(input){
console.log(input); // I get the object
console.log(input.id); //1
//testdata below
test = {"id":"1","fname":"Test","lname":"Name"};
console.log(test); // I get the object
console.log(test.id); //1
},"json"); //using ',"json"' is working on the test.php file now
但我认为这不适合头部问题
答案 0 :(得分:1)
在index.php页面上使用此语句
<?php error_reporting(0); ?>
由于您使用的是mysql_query,因此会为不推荐使用的函数提供警告消息,从而导致错误。整个警告消息将返回到您的页面,该页面不是您期望的格式。该声明将取消警告,应该没问题。但我建议你使用PDO或mysqli。