公司一个新的需求导出Exce表格,研究了一下,最后终于实现,分享给大家。
1 使用FileSaver
第一次采用FileSaver.js 由于刚开始导致导出一片空白,还只能抓取网页里面的表格地址:https://github.com/eligrey/FileSaver.js
HTML
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]);
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('数据导出成功!')
})
}
})
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。