原導出Excel
原始指令原始導出
Excel#指令, AngularJS 匯出Excel指令。
這是用戶的需求,單位申請檢定器具,可以申請一次檢定多個器具,技術機構的人員拿到的印刷表格去聯絡部門檢定,所以表格中應該是有器具的表格訊息,同時還有申請單位、聯絡電話等資訊。 剛閱讀完官方文檔,在不影響原指令的使用情況下,我們可以去再設定一個可選的extraData參數,如果傳入該參數,就把這個放到表格的頭部,未傳入,即相容原指令使用,以原方法輸出表格。 (想看更多就到PHP中文網
angularjs學習手冊中學習)
extraData,綁定模式加上
?
scope: { extraData: '=?', // = 双向绑定,?表示该属性可选 tableId: '@', // 表格id exportCols: '@', // 表格导出的列数,为了解决编辑删除按钮的问题,如果全部导出会将编辑删除的代码一并导出 multipleRowCols: '@', // 表格中有效数据跨行的列数,添加空,用于显示跨行效果 noMultipleRowCols: '@', // 整个表格中不跨行的列数,用户判断该行为正常行还是跨行行 csvName: '@' // 导出表格名称 }
資料結構設計
因為需要在一項中傳入要額外添加的所有信息,所以這裡最好的資料結構應該是。
// 如果传入了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表格匯出訊息的過程的詳細內容。更多資訊請關注PHP中文網其他相關文章!