0

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 />";
}

?>
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 に答える