美好的一天,我在我的React js
应用程序中运行服务器端数据表脚本,我设法让它显示我的reactstrap
按钮,如下所示:
"columnDefs": [
{
"targets": 4,
"data": null,
"createdCell": function (td, cellData, rowData, row, col){
return _this.datatableButtons(td);
}
}
]
datatableButtons(td) {
ReactDOM.render(
<ButtonGroup>
<Button className="btn-icon btn-icon-only" color="primary" title="Edit Branch">
<i className="pe-7s-pen btn-icon-wrapper"> </i>
</Button>
<Button className="btn-icon btn-icon-only" color="warning" title="Activate Branch">
<i className="pe-7s-switch btn-icon-wrapper"> </i>
</Button>
<Button className="btn-icon btn-icon-only" color="danger" title="Delete Branch" onClick={() => this.deleteBranch()}>
<i className="pe-7s-trash btn-icon-wrapper"> </i>
</Button>
</ButtonGroup>, td);
}
这很棒,但每当我测试它的响应视图时,它不再显示按钮,而是在所有隐藏的表行上显示[object Object]
。我很想知道是否有解决方案。
我设法通过添加此代码来解决它:
'responsive': {
details: {
renderer: function ( api, rowIdx, columns ) {
var data = $.map( columns, function ( col, i ) {
if(col.columnIndex == 3) {
var result = '';
if (col.hidden) {
result = '<tr data-dt-row="'+col.rowIndex+'" data-dt-column="'+col.columnIndex+'">'+
'<td>'+
'<ul class="dtr-details">'+
'<li>'+
'<span class="dtr-title">'+col.title+':'+'</span> ';
if($.trim(col.data.activate).toUpperCase() == 'ACTIVE')
result += '<label class="switch"><input type="checkbox" name="active" value="active" checked /><span class="slider"></span></label>';
else
result += '<label class="switch"><input type="checkbox" name="active" value="active" /><span class="slider"></span></label>';
result += '</li>'+
'</ul>'+
'</td>'+
'</tr>';
}
return result;
}else if(col.columnIndex == 4) {
return col.hidden ?
'<tr data-dt-row="'+col.rowIndex+'" data-dt-column="'+col.columnIndex+'">'+
'<td>'+
'<ul class="dtr-details">'+
'<li>'+
'<span class="dtr-title">'+col.title+':'+'</span> '+
'<div class="btn-group">'+
'<button type="button" class="btn btn-icon btn-icon-only btn-primary" title="Edit Branch"><i class="pe-7s-pen btn-icon-wrapper"> </i></button>'+
'<button type="button" class="btn btn-icon btn-icon-only btn-danger delete_branch" id="del_'+col.rowIndex+'"><i class="pe-7s-trash btn-icon-wrapper"> </i></button>'+
'</div>'+
'</li>'+
'</ul>'+
'</td>'+
'</tr>' :
'';
} else {
return col.hidden ?
'<tr data-dt-row="'+col.rowIndex+'" data-dt-column="'+col.columnIndex+'">'+
'<td>'+
'<ul class="dtr-details">'+
'<li>'+
'<span class="dtr-title">'+col.title+':'+'</span>'+
'<span class="dtr-data">'+col.data+'</span>'+
'</li>'+
'</ul>'+
'</td>'+
'</tr>' :
'';
}
} ).join('');
return data ?
$('<table/>').append( data ) :
false;
}
}
}
我使用香草引导代替