0

私はjQueryが初めてで、Firebugでこのajax呼び出しをデバッグできませんでした:

これは私のajax呼び出しです:

var styndx = $('#studylist option:selected').val();
var studyname = $('#edit_field').val();


$.post("saveStudyName.php", {'type': 'update', 'studyname':studyname, 'styndx':styndx},
    function(resultmsg) {
    $('#edit_field').val('');
    $('#savebtn').attr('disabled',true);
    refresh_studynames();
});

これが関数 refresh_studynames です。

function refresh_studynames()
{
  $.ajax({                                      
     url: 'getStudyNames.php',                  
     data: "",                                                             
     dataType: 'json',               
          error: function() {
            alert('Refresh of study names failed.');
          },
     success: function(data)
     {
        $data.each(data, function(val, sname) {
        $('#studylist').append( $('<option></option>').val(val).html(sname) )
      });
     } 
  });
}

最後に、これは PHP スクリプト getStudyNames.php です ($dbname、$dbconnect、$hostname はすべて読み込まれ、$dbconnect が機能します。バックエンド データベースは Postgres であり、pg_fetch_allは結果を配列として返す PHP の Postgres 関数です):

$dbconnect = pg_pconnect("host=".$hostname." user=".$dbuser." dbname=".$dbname);    
    if (!$dbconnect)    {
        showerror(0,"Failed to connect to database",'saveStudyName',30,"username=".$dbuser.", dbname=".$dbname);
        exit;
    }

    $sql = "SELECT ST.studyindex,ST.studyabrv AS studyname
            FROM ibg_studies ST
            ORDER BY studyname";


    $fetchresult = pg_exec($dbconnect, $sql);
    if ($fetchresult) {
        $array = pg_fetch_all($fetchresult);
        echo json_encode($array);
    } else {
        $msg = "Failure! SQL="+$sql;
        echo $msg;
    }

どんな助けでも大歓迎です....

4

1 に答える 1

1

この線

$('#studylist').append( $('<option></option>').val(val).html(sname) );

間違っているように見えます。

よくわかりませんが、試してみてください:

var $studylist = $('#studylist').empty();
$data.each(data, function(i, record) {
    $studylist.append( $('<option/>').html(record.sname) );
});
于 2012-12-07T02:09:47.990 に答える