>웹 프론트엔드 >JS 튜토리얼 >AngularJS 테이블 내보내기로 추가 정보 추가

AngularJS 테이블 내보내기로 추가 정보 추가

不言
不言원래의
2018-07-09 15:56:041321검색

이 글은 주로 참고할 가치가 있는 AngularJS 테이블 내보내기에 대한 추가 정보를 소개합니다. 이제 필요한 친구들이 참고할 수 있습니다.

원본 명령

원본 내보내기 Excel 명령 , AngularJS는 Excel 지침을 내보냅니다. Excel指令,AngularJS 导出Excel指令。

AngularJS 테이블 내보내기로 추가 정보 추가

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

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

AngularJS 테이블 내보내기로 추가 정보 추가

사용자의 요구 사항입니다. 한 기기에서 장비 교정을 신청할 때 여러 장비의 교정을 동시에 신청할 수 있습니다. 기술 기관 직원이 인쇄된 양식을 받아 해당 부서에 교정을 문의합니다. , 따라서 양식에는 기기의 테이블 정보가 포함되어야 하며 동시에 신청자 단위 및 연락처와 같은 정보도 포함되어야 합니다.

AngularJS 테이블 내보내기로 추가 정보 추가공식 문서를 모두 읽었습니다. 원래 명령의 사용에 영향을 주지 않고 선택적 extraData 매개변수를 설정할 수 있습니다. 헤더가 전달되지 않으면 원래 명령어와 호환되며 테이블은 원래 방법에 따라 출력됩니다.

명령 개선

명령에 매개 변수 extraData를 추가하고 바인딩 모드에 ?를 추가하여 이 속성이 선택 사항임을 나타냅니다.

// 生成额外的数据信息,用于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;
};

데이터 구조 설계 하나의 항목에 있어야 하기 때문에 추가할 추가 정보가 모두 전달되므로 여기서 가장 적합한 데이터 구조는 Map이어야 합니다.
rrreee

Map을 트래버스하고, 키-값 쌍을 연결하고, 루프를 통과할 때마다 줄바꿈을 추가합니다. 🎜🎜🎜🎜위 내용은 모두의 학습에 도움이 되기를 바랍니다. PHP 중국어 웹사이트로! 🎜🎜관련 권장 사항: 🎜🎜🎜angularjs 데이터 바인딩🎜🎜🎜🎜🎜jQuery/Vue 마우스 이동 및 이동 효과🎜🎜🎜

위 내용은 AngularJS 테이블 내보내기로 추가 정보 추가의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.