公司一个新的需求导出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
相关文章:
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
建站之星安装后如何配置SEO及设计样式?
Python多线程使用规范_线程安全解析【教程】
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
宝塔新建站点为何无法访问?如何排查?
网站设计制作企业有哪些,抖音官网主页怎么设置?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
网站按钮制作软件,如何实现网页中按钮的自动点击?
微信推文制作网站有哪些,怎么做微信推文,急?
个人摄影网站制作流程,摄影爱好者都去什么网站?
临沂网站制作企业,临沂第三中学官方网站?
如何快速生成高效建站系统源代码?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
如何快速生成可下载的建站源码工具?
建站之星导航配置指南:自助建站与SEO优化全解析
如何选择香港主机高效搭建外贸独立站?
,在苏州找工作,上哪个网站比较好?
黑客如何利用漏洞与弱口令入侵网站服务器?
如何快速打造个性化非模板自助建站?
怎么将XML数据可视化 D3.js加载XML
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
建站主机服务器选购指南:轻量应用与VPS配置解析
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
孙琪峥织梦建站教程如何优化数据库安全?
长沙做网站要多少钱,长沙国安网络怎么样?
南宁网站建设制作定制,南宁网站建设可以定制吗?
网站制作壁纸教程视频,电脑壁纸网站?
如何用5美元大硬盘VPS安全高效搭建个人网站?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
如何基于云服务器快速搭建网站及云盘系统?
,怎么用自己头像做动态表情包?
如何选择高性价比服务器搭建个人网站?
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
如何在IIS管理器中快速创建并配置网站?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
济南企业网站制作公司,济南社保单位网上缴费步骤?
湖北网站制作公司有哪些,湖北清能集团官网?
模具网站制作流程,如何找模具客户?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
建站之星如何快速解决建站难题?
Python lxml的etree和ElementTree有什么区别
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
如何获取上海专业网站定制建站电话?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
如何高效利用亚马逊云主机搭建企业网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。