首頁  >  文章  >  web前端  >  AngularJS表格如何匯出新增資訊?幾分鐘告訴你關於angularjs表格匯出訊息的過程

AngularJS表格如何匯出新增資訊?幾分鐘告訴你關於angularjs表格匯出訊息的過程

寻∝梦
寻∝梦原創
2018-09-07 14:47:121221瀏覽

本篇文章主要的額講述了關於angularjs表格導出添加額外資訊的問題,本文章裡麵包括了angularjs表格匯出資訊的整個過程,希望對大家有用,現在我們一起來看這篇文章吧

原始指令

原導出Excel

原始指令AngularJS表格如何匯出新增資訊?幾分鐘告訴你關於angularjs表格匯出訊息的過程原始導出

Excel

#指令, AngularJS 匯出Excel指令。

這是用戶的需求,單位申請檢定器具,可以申請一次檢定多個器具,技術機構的人員拿到的印刷表格去聯絡部門檢定,所以表格中應該是有器具的表格訊息,同時還有申請單位、聯絡電話等資訊。

剛閱讀完官方文檔,在不影響原指令的使用情況下,我們可以去再設定一個可選的

extraData參數,如果傳入該參數,就把這個放到表格的頭部,未傳入,即相容原指令使用,以原方法輸出表格。 (想看更多就到PHP中文網angularjs學習手冊中學習)

指令完善

指令加一個參數

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

進行遍歷,拼接鍵值對,每迴圈一次加一個換行。

建構AngularJS表格如何匯出新增資訊?幾分鐘告訴你關於angularjs表格匯出訊息的過程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;
};

實作效果:

######這篇文章到這就結束了(想看更多就到PHP中文網###angularjs學習手冊###中學習),有問題的可以在下方留言提問#########

以上是AngularJS表格如何匯出新增資訊?幾分鐘告訴你關於angularjs表格匯出訊息的過程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn