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

1 使用FileSaver
第一次采用FileSaver.js 由于刚开始导致导出一片空白,还只能抓取网页里面的表格地址:https://github.com/eligrey/FileSaver.js
HTML
<div id="exportable">
<table width="100%">
<thead>
<tr>
<th>Name</th>
<th>Email</th>
</tr>
</thead>
<tbody>
<tr>
<td>小明</td>
<td>dsds@163.com</td>
</tr>
</tbody>
</table>
</div>
js部分
var blob = new Blob([document.getElementById('exportable').innerHTML], {
type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8"
});
saveAs(blob, "日记账.xls");
};
2 使用 alasql
使用alasql的好处就是可以在数据层面去组织结构
官网地址:http://alasql.org/
js部分
\\ angular 需要导入xlsx.core.min.js alasql.min.js
\\ 文件结构
var arr = [
{
'收入':1,
'支出':2,
'结存':3
},
{
'收入':4,
'支出':5,
'结存':6
}
]
\\ 生成 excel 文件
alasql('SELECT * INTO XLSX("日记账.xlsx",{headers:true}) FROM ?',[arr]);
我优化的版本
// 导出excel
$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,2),
'结存':$filter('number')(item.balance,2)
})
})
if(arr.length < 1){
ToasterTool.error('暂无数据,导出失败!');
}else{
// alasql('SELECT * INTO XLSX("日记账.xlsx",{headers:true}) FROM ?',[arr]);
alasql.promise('SELECT * INTO XLSX("日记账-'+ DateTool.format(new Date(),'yyyy-MM-dd HH:mm:ss') + "-"+ $scope.loginUser.userName +'.xlsx",{headers:true}) FROM ?',[arr])
.then(function (data) {
if(data == 1){
$timeout(function(){
ToasterTool.success('数据导出成功!')
})
}
})
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# AngularJs导出Excel
# Angular导出数据到Excel
# JS实现将数据导出到Excel的方法详解
# js实现数据导出为EXCEL(支持大量数据导出)
# Vue导出json数据到Excel电子表格的示例
# JSP实现从数据库导出数据到Excel下载的方法
# js导出table数据到excel即导出为EXCEL文档的方法
# 通过Javascript将数据导出到外部Excel文档的函数代码
# javascript 导出数据到Excel(处理table中的元素)
# javascript 实现纯前端将数据导出excel两种方式
# 暂无
# 给大家
# 刚开始
# 小明
# 官网
# 组织结构
# 大家多多
# 收付
# document
# Blob
# type
# innerHTML
# getElementById
# dsds
# officedocument
相关文章:
学校建站服务器如何选型才能满足性能需求?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
网页设计与网站制作内容,怎样注册网站?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何在阿里云域名上完成建站全流程?
如何选择建站程序?包含哪些必备功能与类型?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
如何在腾讯云服务器快速搭建个人网站?
如何快速搭建FTP站点实现文件共享?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
如何快速配置高效服务器建站软件?
linux top下的 minerd 木马清除方法
活动邀请函制作网站有哪些,活动邀请函文案?
网站微信制作软件,如何制作微信链接?
建站之星如何助力企业快速打造五合一网站?
如何用5美元大硬盘VPS安全高效搭建个人网站?
如何在橙子建站上传落地页?操作指南详解
如何解决VPS建站LNMP环境配置常见问题?
网站app免费制作软件,能免费看各大网站视频的手机app?
h5网站制作工具有哪些,h5页面制作工具有哪些?
用v-html解决Vue.js渲染中html标签不被解析的问题
制作证书网站有哪些,全国城建培训中心证书查询官网?
香港服务器如何优化才能显著提升网站加载速度?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
盐城做公司网站,江苏电子版退休证办理流程?
淘宝制作网站有哪些,淘宝网官网主页?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
北京网站制作公司哪家好一点,北京租房网站有哪些?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
制作旅游网站html,怎样注册旅游网站?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
建站之星如何快速解决建站难题?
Android使用GridView实现日历的简单功能
如何彻底卸载建站之星软件?
香港服务器部署网站为何提示未备案?
如何选择可靠的免备案建站服务器?
如何在云虚拟主机上快速搭建个人网站?
如何用腾讯建站主机快速创建免费网站?
深圳网站制作案例,网页的相关名词有哪些?
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何通过万网虚拟主机快速搭建网站?
黑客如何利用漏洞与弱口令入侵网站服务器?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
如何快速生成ASP一键建站模板并优化安全性?
网站网页制作专业公司,怎样制作自己的网页?
个人摄影网站制作流程,摄影爱好者都去什么网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。