如何在ui-grid angularjs中导出选定的列?

问题描述 投票:1回答:2

我正在使用UI网格导出功能以csv格式导出网格列。我想让用户选择要导出的列。我的问题是如何在列上进行选择?

javascript angularjs angular-ui-grid ui-grid
2个回答
0
投票

说明将导出器功能添加到网格

用作属性

示例index.html

<!doctype html>
<html ng-app="app">
  <head>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.7.0/angular.js">    </script>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.7.0/angular-touch.js"></script>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.7.0/angular-animate.js"></script>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.7.0/angular-aria.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/csv.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/pdfmake.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/vfs_fonts.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/lodash.min.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/jszip.min.js"></script>
    <script src="http://ui-grid.info/docs/grunt-scripts/excel-builder.dist.js"></script>
    <script src="/release/ui-grid.js"></script>
    <link rel="stylesheet" href="/release/ui-grid.css" type="text/css">
    <script src="app.js"></script>
  </head>
  <body>
    <div ng-controller="MainCtrl">
    <div ui-grid="gridOptions" ui-grid-exporter></div>
       </div>
     </body>
   </html>

app.js文件

var app = angular.module('app', ['ui.grid', 'ui.grid.exporter']);

app.controller('MainCtrl', ['$scope', function ($scope) {
   $scope.data = [
     { name: 'Bob', title: 'CEO' },
         { name: 'Frank', title: 'Lowly Developer' }
   ];

   $scope.gridOptions = {
     enableGridMenu: true,
     exporterMenuCsv: false,
     columnDefs: [
       {name: 'name', enableCellEdit: true},
       {name: 'title', enableCellEdit: true}
     ],
     data: $scope.data
   };
 }]);

看到这个Adds exporter features to grid

更新:列上的选择可以在样本中找到


0
投票

因此,没有合适的方法来导出所选列。顺便说一句,我将uiGridExporterConstants更改为'VISIBLE',并在将网格发送到导出服务之前更改了列的可见性。这适合我。

© www.soinside.com 2019 - 2024. All rights reserved.