如何在angular js ui Grid中删除pdf导出中的某些列

时间:2015-01-07 02:11:56

标签: javascript angularjs ng-grid angular-ui-grid pdfmake

我正在使用Angular JS ui Grid

http://ui-grid.info/docs/#/tutorial/312_exporting_data_complex

我的要求是我要展示,例如5列,但是当我导出PDF时,我不想导出某些列,例如username

我该怎么做?

4 个答案:

答案 0 :(得分:24)

有一个gridOption可以做到这一点:exporterSuppressColumns

我从UI Grid文档编辑了plunker,以演示隐藏"性别"导出的PDF中的列: http://plnkr.co/edit/89ZVlPZcQbHYzgX5l4yq?p=preview

现在是否选择导出"全部"或导出"可见",您将永远不会在输出中看到性别列。

  $scope.gridOptions = {
columnDefs: [
  { field: 'name',visible:true },
  { field: 'gender', cellFilter: 'mapGender', exporterPdfAlign: 'right', visible:true, enableHiding: true },
  { field: 'company', visible: false }
],
exporterSuppressColumns: [ 'gender' ],

文档在这里:http://ui-grid.info/docs/#/api/ui.grid.exporter.api:GridOptions

答案 1 :(得分:2)

exporterSuppressExport:true

示例

{
 name: 'Description', enableCellEdit: true,
 cellTemplate: '<div class="ui-grid-cell-contents"><div ng-class="{\'viewr-dirty\' : row.inlineEdit.entity[col.field].isValueChanged }">{{row.entity[col.field]}}</div></div>'
},

有关详细信息,请参阅此处http://ui-grid.info/docs/#/api/ui.grid.exporter.api:ColumnDef

答案 2 :(得分:1)

现在这是一个包含按钮的列,需要从导出中排除

{
name: null,
exporterSuppressExport: true,
field: "fake",
cellTemplate: '<div class="tac"><a class="btn btn-red btn-xs ml5" ng-if="!row.inlineEdit.isEditModeOn" ng-click="grid.appScope.vm.deleteRow(row, $event)"><i class="fa fa-trash"><md-tooltip md-direction="left">delete</md-tooltip></i></a></div>',
enableCellEdit: false,
enableFiltering: false,
enableSorting: false,
showSortMenu: false,
enableColumnMenu: false,
width: 50,
},

答案 3 :(得分:0)

您也可以将选项exporterSuppressExport: true添加到columnDefs中的所需列,如下所示:

$scope.gridOptions = {
  columnDefs: [
    { field: 'username', exporterSuppressExport: true },
    { field: 'someOtherField' }
  ],
  // other options ...
};

现在只导出someOtherField