Javascript 使用AngularJS将HTML表格导出到Excel

Javascript 使用AngularJS将HTML表格导出到Excel,javascript,angularjs,excel,Javascript,Angularjs,Excel,我正在尝试使用angularJS导出excel的html表。我能够做到这一点。但当我导出到excel时,我想删除一些tr和td。如何完成这项任务。提前谢谢 下面是我的角度代码 angular.module('xxxApp').factory('Excel',function($window){ var uri='data:application/vnd.ms-excel;base64,', template='<html xmlns:o="urn:s

我正在尝试使用angularJS导出excel的html表。我能够做到这一点。但当我导出到excel时,我想删除一些tr和td。如何完成这项任务。提前谢谢 下面是我的角度代码

angular.module('xxxApp').factory('Excel',function($window){
        var uri='data:application/vnd.ms-excel;base64,',
            template='<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>',
            base64=function(s){return $window.btoa(unescape(encodeURIComponent(s)));},
            format=function(s,c){return s.replace(/{(\w+)}/g,function(m,p){return c[p];})};
        return {
            tableToExcel:function(tableId,worksheetName){
                var table=$(tableId),
                    ctx={worksheet:worksheetName,table:table.html()},
                    href=uri+base64(format(template,ctx));
                return href;
            }
        };
    })
    .controller('MyExcelCtrl',function(Excel,$timeout,$scope){
      $scope.exportToExcel=function(tableId){ // ex: '#my-table'
            var exportHref=Excel.tableToExcel(tableId,'AdminUsers');
            var a = document.createElement('a');
            a.href = exportHref;
            a.download = 'Admin_Users.xls';
            a.click();
        }
      $scope.isExportToExcel= false;

    });
angular.module('xxxApp').factory('Excel',function($window){
var uri='data:application/vnd.ms excel;base64',
模板=“{table}”,
base64=函数{return$window.btoa(unescape(encodeURIComponent));},
格式=函数(s,c){返回s.replace(/{(\w+)}/g,函数(m,p){返回c[p];})};
返回{
tableToExcel:函数(tableId、工作表名称){
变量表=$(表ID),
ctx={工作表:工作表名称,表:table.html()},
href=uri+base64(格式(模板,ctx));
返回href;
}
};
})
.controller('MyExcelCtrl',函数(Excel、$timeout、$scope){
$scope.exportToExcel=函数(tableId){//ex:“#我的表”
var exportHref=Excel.tableToExcel(tableId,'AdminUsers');
var a=document.createElement('a');
a、 href=exportHref;
a、 下载='Admin_Users.xls';
a、 单击();
}
$scope.isExportToExcel=false;
});

请在这方面帮助我

尝试这项工作,示例1是放入HTML表格元素时的id

  $scope.exportData = function () {

        debugger;
        var uri = 'data:application/vnd.ms-excel;base64,'
            , template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{CouponDetails}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>'
            , base64 = function (s) { return window.btoa(unescape(encodeURIComponent(s))) }
            , format = function (s, c) { return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; }) }

        var table = document.getElementById("example1");
         var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML };
        var url = uri + base64(format(template, ctx));
        var a = document.createElement('a');
        a.href = url;
        a.download = 'Expoerdata.xls';
        a.click();
    };
$scope.exportData=函数(){
调试器;
var uri='data:application/vnd.ms excel;base64,'
,模板=“{table}”
,base64=函数{return window.btoa(unescape(encodeURIComponent))}
,format=函数(s,c){返回s.replace(/{(\w+)}/g,函数(m,p){返回c[p];})}
var table=document.getElementById(“示例1”);
var ctx={工作表:名称| |'工作表',表:table.innerHTML};
var url=uri+base64(格式(模板,ctx));
var a=document.createElement('a');
a、 href=url;
a、 下载='exporedata.xls';
a、 单击();
};

尝试此工作,示例1是放入HTML表格元素时的id

  $scope.exportData = function () {

        debugger;
        var uri = 'data:application/vnd.ms-excel;base64,'
            , template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{CouponDetails}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>'
            , base64 = function (s) { return window.btoa(unescape(encodeURIComponent(s))) }
            , format = function (s, c) { return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; }) }

        var table = document.getElementById("example1");
         var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML };
        var url = uri + base64(format(template, ctx));
        var a = document.createElement('a');
        a.href = url;
        a.download = 'Expoerdata.xls';
        a.click();
    };
$scope.exportData=函数(){
调试器;
var uri='data:application/vnd.ms excel;base64,'
,模板=“{table}”
,base64=函数{return window.btoa(unescape(encodeURIComponent))}
,format=函数(s,c){返回s.replace(/{(\w+)}/g,函数(m,p){返回c[p];})}
var table=document.getElementById(“示例1”);
var ctx={工作表:名称| |'工作表',表:table.innerHTML};
var url=uri+base64(格式(模板,ctx));
var a=document.createElement('a');
a、 href=url;
a、 下载='exporedata.xls';
a、 单击();
};

您是否可以选择导出JSON而不是导出html表?我猜你有一个json数组,它反过来被呈现为html表格。我对json没有控制权,json反过来被呈现为html。我只需要玩html表格。我现在面临的又一个问题。我无法在IE和FireFox浏览器中下载导出的excel,但在Chrome浏览器中工作正常。为了浏览器的可比性,我需要在代码中添加什么吗?您是否可以选择导出JSON而不是导出html表?我猜你有一个json数组,它反过来被呈现为html表格。我对json没有控制权,json反过来被呈现为html。我只需要玩html表格。我现在面临的又一个问题。我无法在IE和FireFox浏览器中下载导出的excel,但在Chrome浏览器中工作正常。为了浏览器的可比性,我需要在代码中添加什么?