0

私はこれを機能させるのに本当に苦労しているので、どんな助けでも大歓迎です!

基本的に、次のようにダブルクリックイベントで予約を表示するJQGRidがあります。

    ondblClickRow: function(rowid)
    {
        rowData = $("#bookings").getRowData(rowid);
                    var brData = rowData['bookref'];

        getGridRow(brData);
    },

これはgetGridRow関数に渡されます:

function getGridRow(brData) {

    $.ajax({
      url: 'bookings-dialog.php',
      data: {'rowdata' : brData },
      dataType: 'json', //this is what we expect our returned data as
     error: function(){
                    alert("It failed");
                    $('#cp-div-error').html('');
                    $('#cp-div-error').append('<p>There was an error inserting the data, please try again later.</p>');
                    $('#cp-div-error').dialog('open');
             },
      success: function(data){
        //empty our dialog so we don't end up with duplicate content
        $('.cp-booking-info').empty();
        //we have told the browser to expect JSON back, no need to do any parsing
        //the date
        $('.cp-booking-info').append('<p class="pno-margin">Booking Date: '+data.bookref+'</p>');

        //now let's manipulate our dialog and open it.
        $("#cp-bookings-dialog").dialog({
          show: { effect: 'drop', direction: "up" },
          hide: 'slide',
          height: 625,
          width: 733,
          title: 'Booking Reference: - '+ brData
        });
      }

    });

そしてこれはbookings-dialog.phpです:

<?php

require_once('deployment.php');
require_once('bootstrp/all.inc.php');
require_once('models/sql.php');
require_once('models/bookingdocket.php');

    $pdo = new SQL();
    $dbh = $pdo->connect(Database::$serverIP, Database::$serverPort, Database::$dbName, Database::$user, Database::$pass);

    try {
           $rowdata = $_POST['rowdata'];

           $query = ("SELECT * FROM tblbookings WHERE bookref = '$rowdata'");

        $stmt = $dbh->prepare($query);

        $stmt->execute();

        $row = $stmt->fetch(PDO::FETCH_BOTH);

           BookingDocket::set_id($row['id']);
           BookingDocket::set_bookref($row['bookref']);
           BookingDocket::set_bookdate($row['bookingdate']);
           BookingDocket::set_returndate($row['returndate']);
           BookingDocket::set_journeytype($row['journeytype']);
           BookingDocket::set_passtel($row['passengertel']);
           BookingDocket::set_returndate($row['returndate']);

           $booking_ref = BookingDocket::get_bookref();


           return json_encode(array('bookref' => $booking_ref,
                                    )
                             );




        $stmt->closeCursor();

    }

    catch (PDOException $pe) {
        die("Error: " .$pe->getMessage(). " Query: ".$stmt->queryString);
    }

    $dbh = null;





?>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Title Work</title>
<link rel="stylesheet" type="text/css" href="css/main.css" />
<link rel="stylesheet" type="text/css" href="css/styles.css" />
<link rel="stylesheet" type="text/css" href="lib/jq-ui/jquery-ui-1.8.16.custom.css" />
<link rel="stylesheet" type="text/css" href="lib/jq-grid/ui.jqgrid.css" />
<script type="text/javascript" src="scripts/js/utils/util-sha256.js"></script>
<script type="text/javascript" src="lib/jq-core/jquery-1.4.4.min.js" ></script>
<script type="text/javascript" src="lib/jq-ui/jquery-ui-1.8.16.custom.min.js" ></script>
<script type="text/javascript" src="lib/jq-grid/grid.locale-en.js"></script>
<script type="text/javascript" src="lib/jq-grid/jquery.jqGrid.min.js" ></script>
<script type="text/javascript" src="scripts/js/interface-datagrids.js"></script>
<script type="text/javascript" src="scripts/js/image-preload.js"></script>
<script type="text/javascript" src="scripts/js/general-interface.js" ></script>
<script type="text/javascript" src="scripts/js/general-controlpanel.js" ></script>
<script type="text/javascript" src="scripts/js/general-validation.js"></script>

</head>

<body>

<div id="cp-bookings-dialog">
  <div class="cp-tiles-wrapper-dlg">
    <div class="cp-booking-info left">
    </div>
  </div>
</div>


</body>
</html>

私が達成しようとしているのは、予約をダブルクリックすると、予約参照(eg BR12345)がbookings-dialog.phpに渡され、クエリ(eg SELECT * FROM tblbookings WHERE bookref = '$rowdata')で使用されることです。これを実現するためにJSONを使用しようとしていますが、行をダブルクリックした時点では失敗しているだけで、理由はわかりません。

助言がありますか?

4

2 に答える 2

2

試す:

   $.ajax({
      type: 'POST',  //ADD THIS .ajax defaults to GET and in the php you expect POST
      url: 'bookings-dialog.php',
      data: {'rowdata' : brData },
于 2012-08-23T13:45:22.337 に答える
1

AJAX呼び出しのデフォルトのHTTPタイプはGETです。POSTに変更する必要があります。

$.ajax({
type:'POST',
...

http://api.jquery.com/jQuery.ajax/

于 2012-08-23T13:45:55.897 に答える