MVC 导出Execl 的总结几种方式 (二)

  接着上面的来,继续导出Execl 的功能

  使用FileResult 方式直接可以生产Execl ,这样我们将会写大量处理后台的代码,个人感觉不好,只是展示出来,提供参考

 

第一步:编辑控制器

 

 public FileResult ExportFile()
        {
            var list = GetList();

            var sbHtml = new StringBuilder();
            string title = "order";
            //标题
            sbHtml.Append("<table border='1' cellspacing='0' cellpadding='0'>");
            sbHtml.Append("<tr>");
            sbHtml.AppendFormat("<td style='font-size: 14px;text-align:center; font-weight:bold;' height='30' colspan='3'>{0}</td>", title);
            sbHtml.Append("</tr>");
            sbHtml.Append("</table>");
            sbHtml.Append("<table border='1' cellspacing='0' cellpadding='0' style='font-size: 12px;'>");
            var lstTitle = new List<string> { "Year", "Week", "Date" }; //编写表头
            sbHtml.Append("<tr>");
            foreach (var item in lstTitle)
            {
                sbHtml.AppendFormat("<td style='text-align:center;background-color: #DCE0E2; font-weight:bold;' height='25'>{0}</td>", item);
            }
            sbHtml.Append("</tr>");
            int i = 1;

            var strDataType = string.Empty;
            var strQuestion = string.Empty;

            foreach (var item in list)
            {

                sbHtml.Append("</tr>");
                sbHtml.AppendFormat("<td align='center'>{0}</td><td align='center'>{1}</td><td align='center'>{2}</td>", item.Id, item.Name,item.CreateTime.ToString("yyyy-MM-dd hh:mm:ss") );
                sbHtml.Append("</tr>");
                i++;

            }
            sbHtml.Append("</table>");

            byte[] fileContents = Encoding.Default.GetBytes(sbHtml.ToString());

            string fileName = title + ".xls";

            if (Request.Browser.Browser == "IE")
            {
                Response.Charset = "GB2312";
                Response.ContentEncoding = Encoding.GetEncoding("GB2312");
                Response.AddHeader("Content-Disposition", string.Format("attachment; filename=\"{0}\"", HttpUtility.UrlEncode(fileName, Encoding.UTF8)));
            }
            return File(fileContents, "application/ms-excel", fileName);
        }
View Code

 

第二步:前端调用

  function ExportFile() {

        window.open("/Home/ExportFile");
      
    }

 

 OK ,这样就好 控制器里面的代码也是挺简单,自己看看吧

 

posted on 2016-08-19 16:10  IT小伙儿  阅读(194)  评论(0编辑  收藏  举报