最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

AngularJS表格导出添加额外信息

来源:动视网 责编:小采 时间:2020-11-27 19:33:58
文档

AngularJS表格导出添加额外信息

AngularJS表格导出添加额外信息:这篇文章主要介绍了关于AngularJS 表格导出添加额外信息,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下原指令原导出Excel指令,AngularJS 导出Excel指令。这是用户的需求,单位申请检定器具,可以申请一次检定多个器具,技术机构的人员拿到
推荐度:
导读AngularJS表格导出添加额外信息:这篇文章主要介绍了关于AngularJS 表格导出添加额外信息,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下原指令原导出Excel指令,AngularJS 导出Excel指令。这是用户的需求,单位申请检定器具,可以申请一次检定多个器具,技术机构的人员拿到
 这篇文章主要介绍了关于AngularJS 表格导出添加额外信息,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

原指令

原导出Excel指令,AngularJS 导出Excel指令。

这是用户的需求,单位申请检定器具,可以申请一次检定多个器具,技术机构的人员拿到的打印表格去联系部门检定,所以表格中应该是有器具的表格信息,同时还有申请单位、联系电话等信息。

刚阅读完官方文档,在不影响原指令的使用情况下,我们可以去再设置一个可选的extraData参数,如果传入该参数,就把这个放到表格的头部,未传入,即兼容原指令使用,按原方法输出表格。

指令完善

指令加一个参数extraData,绑定模式加?,表示该属性可选

scope: {
 extraData: '=?', // = 双向绑定,?表示该属性可选
 tableId: '@', // 表格id
 exportCols: '@', // 表格导出的列数,为了解决编辑删除按钮的问题,如果全部导出会将编辑删除的代码一并导出
 multipleRowCols: '@', // 表格中有效数据跨行的列数,添加空,用于显示跨行效果
 noMultipleRowCols: '@', // 整个表格中不跨行的列数,用户判断该行为正常行还是跨行行
 csvName: '@' // 导出表格名称
}

数据结构设计

因为需要在一项中传入要额外添加的所有信息,所以这里最好的数据结构应该是Map

// 如果传入了extraData的话,表示有额外的数据,添加到表格头
if (scope.hasOwnProperty('extraData')) {
 // foreach传入的map
 scope.extraData.forEach(function(value, key) {
 // 对于null/undefined的数据采用空字符替换
 let tempValue = value ? value : '';
 // 拼接到数据中
 csvString = csvString + key + "," + tempValue + "\n";
 });
}

Map进行遍历,拼接键值对,每循环一次加一个换行。

构建Map

// 生成额外的数据信息,用于Excel导出使用
self.generateMapForExcelExtraData = function() {
 var map = new Map();
 map.set('申请日期', $filter('date')($scope.work.apply.applyTime));
 map.set('申请单位', $scope.work.apply.department.name);
 map.set('申请人', $scope.work.apply.createUser.name);
 map.set('联系电话', $scope.work.apply.createUser.mobile);
 map.set('检定场所', $scope.work.apply.checkPlace);
 map.set('申请备注', $scope.work.apply.remarks);
 map.set('申请ID', $scope.work.apply.id);
 map.set('受理部门', $scope.work.apply.auditingDepartment.name);
 map.set('受理人', $scope.work.apply.auditingUser.name);
 map.set('受理人电话', $scope.work.apply.auditingUser.mobile);
 map.set('计划检定日期', $scope.work.apply.plannedCheckDate);
 map.set('受理备注', $scope.work.apply.replyRemarks);
 $scope.extraData = map;
};

实现效果:

文档

AngularJS表格导出添加额外信息

AngularJS表格导出添加额外信息:这篇文章主要介绍了关于AngularJS 表格导出添加额外信息,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下原指令原导出Excel指令,AngularJS 导出Excel指令。这是用户的需求,单位申请检定器具,可以申请一次检定多个器具,技术机构的人员拿到
推荐度:
标签: 表格 添加 导出
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top