-1

アプリに大きな問題があります。PHP Webサービスに接続し、ボタンを押すとデータを取得するアプリケーションがあります。唯一の問題は、サービスが応答しておらず、その理由が分からないことです。

サーバーに 'Windesheim' を送信したいのですが、サーバー (ハードコードされています) は 'Windesheim' を返します。テストにはアレイを使用していません。Google Chrome を使用しています。

これは私の.htmlです:

<html>
<head>
    <title>Ekiden</title>
    <script src="http://code.jquery.com/jquery-1.8.2.js"></script>
    <script type="text/javascript" src="_Script.js"></script>       
</head>
<body>
    <input id="team" type="text"/><input id="button" type="button" value="Go" />

    <div id="feedback"></div>
</body>
</html>

これは私の.jsです:

$('#button').click(function() {
var team = $('#team').val();

$.POST('_Dataserver.php', {team: team }, function(data) {
    $('#feedback').text(data);
});
});

そして、これは私の.phpです:

<?php
header('Content-Type: application/json');

$teams = array
(
"Windesheim"=>array
    (
        // Naam, Leeftijd, Tijd, Afstand, Gemiddelde snelheid
        1 => array ('Alfred', 20, 0, 0, 0),
        2 => array ('Willem', 36, 0, 0, 0),
        3 => array ('Michael', 22, 0, 0, 0),
        4 => array ('Stefan', 27, 0, 0, 0),
        5 => array ('Timmy', 20, 0, 0, 0),
        6 => array ('Pascal', 20, 0, 0, 0)
    ),
"Deltion"=>array
    (
        // Naam, Leeftijd, Tijd, Afstand, Gemiddelde snelheid
        1 => array ('Simon', 21, 0, 0, 0),
        2 => array ('Manuel', 33, 0, 0, 0),
        3 => array ('Stephan', 29, 0, 0, 0),
        4 => array ('Marko', 42, 0, 0, 0),
        5 => array ('Nick', 23, 0, 0, 0),
        6 => array ('Achmed', 20, 0, 0, 0)
    ),
"Landstede"=>array
    (
        // Naam, Leeftijd, Tijd, Afstand, Gemiddelde snelheid
        1 => array ('Patrick', 20, 0, 0, 0),
        2 => array ('Mohammed', 18, 0, 0, 0),
        3 => array ('Wilson', 19, 0, 0, 0),
        4 => array ('Walie', 22, 0, 0, 0),
        5 => array ('Marco', 52, 0, 0, 0),
        6 => array ('Mohabie', 45, 0, 0, 0)
    )
);

// Als er teams worden opgevraagd
if (isset($_POST['team'])) 
{
    $team = $_POST['team'];
    if($team == 'Windesheim')
    {
        //echo json_encode($teams[$team]);
        echo json_encode('Windesheim');
    }
}
// Als er niks wordt opgevraagd
else 
{
    echo '';
}

?>
4

2 に答える 2

3

_Scripts.js のコードを document.ready 関数でラップする必要があります。

DOM がレンダリングされる前にコードが実行されるため、 $('#button') は要素を返しません。

_Scripts.js は次のようになります。

$(document).ready(function() {
    var team = $('#team').val();
    $.POST('_Dataserver.php', {team: team }, function(data) {
        $('#feedback').text(data);
    });
});
于 2013-06-18T10:40:38.317 に答える
0
$(document).ready(function() {
});

上記のコードが js コードにありません。

また、

PHP では、要求/投稿値から値 'Windesheim' をチェックしようとしています。

if($team == 'Windesheim') {
    //echo json_encode($teams[$team]);
    echo json_encode('Windesheim');
}

しかし、JS では、チーム ID の値が空であることを渡しているため、html 入力タイプの値として、

<input id="team" type="text"/>

したがって、クライアント側のphpから何も印刷/応答しません。

解決するには、HTML で値 '' を 'Windesheim' に変更してください

(すなわち)<input id="team" type="text" value ="Windesheim"/>

于 2013-06-18T10:37:44.557 に答える