0

私は同様の質問を見つけましたが、それは私を助けませんでした(他の質問者も明らかに...)。だからここに行きます:

製品でグリッドを作ろうとしています。製品ごとに、注文を表示するサブグリッドが必要です。

サブグリッドにデータを読み込めません。'load_sub_data_json.php'が読み込まれることはありません...

これがJSの私のHTMLファイルです:

<pre>
jQuery(document).ready(function() { 
  $("#list").jqGrid({
    height: 'auto',
    blockui: true,
    altRows: true,
    loadonce: true,
    url:'load_main_data_json.php',
    datatype: 'json',
    mtype: 'GET',
    colNames:['ProductCode','ProductName', 'ProductVendor'],
    colModel :[ 
      {name:'productcode', index:'productcode', width:100, align:'right'}, 
      {name:'productname', index:'productname', width:280, align:'right'}, 
      {name:'productvendor', index:'productvendor', width:200, align:'right'}
    ],
    rowNum:35,
    rowList:[25,50,75,100,125,150,175,200],
    sortname: 'productcode',
    sortorder: 'desc',
    viewrecords: true,
    caption: 'My first grid',
    subGrid: true,
    subGridUrl: 'load_sub_data_json.php',
    subGridModel: [
      { name  : ['Order number','Order date','Shipped date','Comments'],
        index : ['orderNumber', 'orderDate', 'shippedDate', 'comments'], 
        width : [55,100,100,200],
        align : ['right','right','right','right'],
        params: ['productcode']
      } 
    ]
  });
});
</pre>

そして、これはサブグリッドにデータをロードする私のphpファイルです:

<pre> 

include("dbconfig.php");

$id = $_REQUEST['id'];
$productCode = $_REQUEST['productcode']; // param passed by query


// connect to the database
$db = mysql_connect($dbhost, $dbuser, $dbpassword) or die("Connection Error: " .     mysql_error());

// select database
mysql_select_db($database) or die("Error conecting to db.");

// select columns
$SQL = "select o.orderNumber, o.orderDate, o.shippedDate, o.comments from orderdetails d inner join orders o on o.orderNumber = d.orderNumber where d.productcode='" . $id. "';";

$result = mysql_query( $SQL ) or die("Couldnt execute query.".mysql_error());

$response = new stdClass;
$i=0;
while($row = mysql_fetch_array($result,MYSQL_ASSOC)) {
    $response->rows[$i]['id']=$row['orderNumber'];
    $response->rows[$i]    ['cell']=array($row['orderNumber'],$row['orderDate'],$row['shippedDate'],$row['comments']);
    $i++;
}

echo json_encode($response);

</pre>
4

1 に答える 1

0

subGridModel のマッピングが欠落していると思います

これを試して、追加してください

mapping : ['orderNumber', 'orderDate', 'shippedDate', 'comments'],
于 2013-03-16T04:25:05.090 に答える