没有从JQuery中的PHP脚本返回数据

时间:2012-10-07 10:47:43

标签: php jquery

我正在学习如何将JQuery,AJAX和PHP集成在一起。

我的问题是我的成功函数没有从参数获得任何值而只是得到'0'。我也不确定我做错了什么,但我刚刚学习了这个教程JQuery & PHP Tutorial并且只是复制了他如何使用回声和参数变量r从PHP代码中获取值。

我已经尝试过搜索解决方案,但我不确定是否有任何结果与我正在做的事情相关。我尝试了他们的一些建议,但似乎没有工作(jQuery的承诺)

我希望有人可以告诉我我做错了什么,因为我渴望学习更多PHP和jQuery。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script>
    $(function () {
        jQuery("form").submit(function(e) { 
             var input = $("#input").val();
             var url = 'input=' + input;
             $.ajax({
               type: "POST",
               url: "process.php",
               data: url,
               success: function(r) {
                   $("#output").text(function(r) {
                        return r;
                   });
               }
             });
             e.preventDefault();
        });
    });
</script>
<title>Insert title here</title>
</head>
<body>
    <form action="process.php" method="post">
        Inputs:<br />
        <textarea rows="15" cols="60" id="input" name="input">Some text...
        </textarea><br /><br />
        Start:
        <input type="text" id="start" name="start" />
        End:
        <input type="text" id="end" name="end" /><br />
        <input type="submit" id="submit" name="submit" value="Submit">
    </form>
    <p id="output">Output: Some Random Text</p>
</body>
</html>

PHP:     

require 'parser.php';
$parser = new Parser();
#header('index.php');
$hash = $parser->parse($_POST['input']);
$keys = array_keys($hash);
foreach($keys as $key) {
    echo "$key ->";
    $dests = $hash[$key];
    foreach($dests as $dest) {
        echo " $dest";
    }
    echo "<br />";
}

?>

1 个答案:

答案 0 :(得分:0)

<script>
    $(function () {
        jQuery("form").submit(function(e) { 
             var input1 = $("#input").val();
             var url = {'input' :  input1};   // a little change to the data parameter
             $.ajax({
               type: "POST",
               url: "process.php",
               data: url,
               success: function(r) {
                //   $("#output").text(r);  //<--- changed to this
                   $("#output").html(r);  // this is better as you output html
               }
             });
             e.preventDefault();
        });
    });
</script>

对于jquery text(),直接使用服务器的返回值。如果要输出html,请使用jquery html()代替