AngularJs导出数据到Excel的示例代码

前端之家收集整理的这篇文章主要介绍了AngularJs导出数据到Excel的示例代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

公司一个新的需求导出Exce表格,研究了一下,最后终于实现,分享给大家。

1 使用FileSaver

第一次采用FileSaver.js 由于刚开始导致导出一片空白,还只能抓取网页里面的表格地址:https://github.com/eligrey/FileSaver.js

HTML

Name Email

js部分

2 使用 alasql

使用alasql的好处就是可以在数据层面去组织结构

官网地址:http://alasql.org/

js部分

sql.min.js \\ 文件结构 var arr = [ { '收入':1,'支出':2,'结存':3 },{ '收入':4,'支出':5,'结存':6 } ]

\ 生成 excel 文件
alasql('SELECT * INTO XLSX("日记账.xlsx",{headers:true}) FROM ?',[arr]);

我优化的版本

$scope.exportToExcel=function(){
var data = angular.copy($scope.pageData.list)
var arr = [];
var type = null;
var amountIN = 0;
var amountOUT = 0;
angular.forEach(data,function (item) {
// 兑付情况
if(item.isHappened){
type = '未兑付'
}else{
type = '已兑付'
}
// 收入
if(item.itemModel=='INCOME'){
amountIN = item.amount
}
// 支出
if(item.itemModel=='OUTCOME'){
amountOUT = item.amount
}
arr.push({
'兑付情况':type,'合同':item.keyId,'收付日期':$filter('date')(item.updateTime,'yyyy-MM-dd'),'科目':item.itemType.value,'收入':$filter('number')(amountIN,2),'支出':$filter('number')(amountOUT,'结存':$filter('number')(item.balance,2)
})
})
if(arr.length < 1){
ToasterTool.error('暂无数据,导出失败!');
}else{
// alasql('SELECT * INTO XLSX("日记账.xlsx",[arr]);

  ala<a href="/tag/sql/" target="_blank" class="keywords">sql</a>.promise('SELECT * INTO XLSX("日记账-'+ DateTool.format(new Date(),'yyyy-MM-dd HH:mm:ss') + "-"+ $scope.loginUser.userName +'.xlsx",[arr])
    .then(function (data) {
      if(data == 1){
        $timeout(function(){
          ToasterTool.success('数据导出成功!')
        })

      }
    })
}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的JavaScript相关文章