后台java,前台JSP实现Excel导出(已经在后台查询,直接在前端实现下载,系统后台整体框架使用SSM)

添加导出功能时系统已经完成了,因为表单中的数据已经经过后台传参,所以不想再改代码,直接用了一个简单的方式,话不多说,下面上代码

<div scrolling="auto" rameborder="0" src="" name="right" width="100%" height="100%">
     <div class="panel-head"><strong class="icon-reorder"> 成绩统计</strong></div></div>
     <button onclick="toexcel()">导出成绩单</button>  //添加导出成绩单按钮

 </div>

<form method="post" name="myform">
  <table id="adminTbody" class="table table-hover text-center">
    <tr>
     <td>成绩</td>
     <td>学号</td>
  <td>学生姓名</td>
  <td>考试名称</td>
    </tr>
    <tbody id="adminTbody">
 <c:forEach items="${list}" var="report">
   <tr>
    <td>${report.score}分</td>
    <td>${report.studentId}</td>
    <td>${report.studentName}</td>
    <td>${report.examName}</td>
   </tr>
 </c:forEach>
 </tbody>
  </table>
</form>


<script type="text/javascript">
    var tableId = document.getElementById('adminTbody'); //adminTbody是table的id属性值
    function toexcel() {
        methodtable2excel(tableId);
    }
    /* Table 生成 Excel */
    var idTmr;
    function  getExplorer() {
        var explorer = window.navigator.userAgent ;
        //ie 
        if (explorer.indexOf("MSIE") >= 0) {
            return 'ie';
        }
        //firefox 
        else if (explorer.indexOf("Firefox") >= 0) {
            return 'Firefox';
        }
        //Chrome
        else if(explorer.indexOf("Chrome") >= 0){
            return 'Chrome';
        }
        //Opera
        else if(explorer.indexOf("Opera") >= 0){
            return 'Opera';
        }
        //Safari
        else if(explorer.indexOf("Safari") >= 0){
            return 'Safari';
        }
    }
    function methodtable2excel(tableid) {//整个表格copy到EXCEL中
        if(getExplorer()=='ie')
        {
            var curTbl = document.getElementById(adminTbody);
            var oXL = new ActiveXObject("Excel.Application");

            var oWB = oXL.Workbooks.Add();
            var xlsheet = oWB.Worksheets(1);
            var sel = document.body.createTextRange();
            sel.moveToElementText(curTbl);//把表格中的内容移到TextRange中 
            sel.select();
            sel.execCommand("Copy");
            xlsheet.Paste();
            oXL.Visible = true;

            try {
                var fname = oXL.Application.GetSaveAsFilename("Excel.xls", "Excel Spreadsheets (*.xls), *.xls");
            } catch (e) {
                print("Nested catch caught " + e);
            } finally {
                oWB.SaveAs(fname);
                oWB.Close(savechanges = false);
                //xls.visible = false;
                oXL.Quit();
                oXL = null;
                //结束excel进程,退出完成
                //window.setInterval("Cleanup();",1);
                idTmr = window.setInterval("Cleanup();", 1);
            }
    }
        else
        {
            tableToExcel(tableid);
        }
    }
    function Cleanup() {
        window.clearInterval(idTmr);
        CollectGarbage();
    }
    var tableToExcel = (function() {
        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]--><meta charset="UTF-8"></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 function(table, name) {
                    if (!table.nodeType) table = document.getElementById(table);
                    var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML};
                    window.location.href = uri + base64(format(template, ctx))
                  }
    })();
</script>

 效果如下:

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值