0

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

我的问题是我的成功函数没有从参数中获取任何值,而只是得到一个“0”。我也不确定自己做错了什么,但我一直在关注本教程JQuery & PHP Tutorial并复制了他如何使用 echoes 和参数变量 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 />";
}

?>
4

1 回答 1

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()

于 2012-10-07T10:59:35.370 回答