0

我有一个来自服务器端的 JSON 数据结构:

"data":[
    { "subdata":{ "type":"RY", "config":{ "cash":200} }
    { "subdata":{ "type":"SR", "config":{ "cash":200, "chips":300} }
    { "subdata":{ "type":"SR", "config":{ "chips":300} }
    { "subdata":{ "type":"RY", "config":{ "bonus":200, "chips":400} }
    { "subdata":{ "type":"SR", "config":{ "bonus":100} }
]

它呈现在视图中的表格中,如下所示:

<table id='table-config'>
    <tr><td>RY</td> <td>cash=200,</td> <td>Mode Amount=200</td></tr>
    <tr><td>SR</td> <td>cash=200,chips=300,</td> <td>Mode Amount=300</td></tr>
    <tr><td>SR</td> <td>chips=200,</td> <td>Mode Amount=200</td></tr>
    <tr><td>RY</td> <td>bonus=200,chips=400,</td> <td></td></tr>
    <tr><td>SR</td> <td>bonus=100,</td> <td>Mode Amount=600</td></tr>
</table>

在渲染数据时,

第一列数据应该给出type=RY/SR,但第一个单元格在发出警告后变为空

DataTables 警告(表 id = 'table-configs'):从第 0 行的数据源请求未知参数 'subdata.type',

第二列数据应该给出配置对象,但第二个单元格在抛出警告后变为空

DataTables 警告(表 id = 'table-configs'):从第 0 行的数据源请求未知参数 'subdata.config',

对于第三列,渲染数据正在工作。

dataTable js 代码为:

function renderAmount(o, config){
    var amount = '';
    $.each(config, function(key, value){
        amount += key + '=' + value + ',';
    });
    return amount;
}

function renderGameMode(o, data){
    var game_mode= (data.type=='RY')? 'cash' : 'chips';
    var mode_value='';
    $.each(data.config, function(key,value){
        if(key == game_mode){
            mode_value = "Mode Amount="+data.config.key;
        }
    });
    return mode_value;
}

$('#table-configs').dataTable({
    'aaData': data.data,
    'bPaginate': false,
    'aoColumns':[
        { 'mDataProp': 'subdata.type' },
        { 'mDataProp': 'subdata.config', 'fnRender': renderAmount },
        { 'mDataProp': 'subdata', 'fnRender': renderGameMode }
    ]
});
4

1 回答 1

0

您在@Pradeep 此处发布的代码有问题。不应该是这样的

<tr><td>cash=200,</td></tr>
<tr><td>cash=200,chips=300,</td></tr>
<tr><td>chips=200,</td></tr>
<tr><td>bonus=200,chips=400,</td></tr>
<tr><td>bonus=100,</td></tr>

如果不是,那可能是代码的问题!

于 2012-09-03T11:12:53.777 回答