• 技术文章 >web前端 >js教程

    AngularJS 表格导出添加额外信息

    不言不言2018-07-09 15:56:04原创615
    这篇文章主要介绍了关于AngularJS 表格导出添加额外信息,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

    原指令

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

    2891695188-5b1b39de57685_articlex[1].png

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

    刚阅读完官方文档,在不影响原指令的使用情况下,我们可以去再设置一个可选的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;
    };

    实现效果:

    258638165-5b1b45e04325d_articlex[1].png

    以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

    相关推荐:

    angularjs的数据绑定

    以上就是AngularJS 表格导出添加额外信息的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:angular.js excel
    上一篇:angularjs的数据绑定 下一篇:AngularJS 文档阅读的指令scope
    千万级数据并发解决方案

    相关文章推荐

    • JavaScript高级语法学习之严格模式• angular学习之浅析HttpClientModule模块• angular学习之路由模块浅析• 浅谈Node第三方框架Express的使用方法• JavaScript学习理解之JSON(总结分享)
    1/1

    PHP中文网