【第十七篇】easyui-datagrid 导出Excel (在客户端能弹出下载框)

    //导出Excel
    function exportExcel(obj) {
        var SaleOrderNo = $("#SaleOrderNo").val().trim();
        var FoctoryNo = $("#FoctoryNo").val().trim();
        var StyleNo = $("#StyleNo").val().trim();

        var href = "/Admin/Sale/ExportPressingExcel?1=1";
        if (SaleOrderNo == "" && FoctoryNo == "" && StyleNo == "" ) {
            href = "/Admin/Sale/ExportPressingExcel";
        } else if (SaleOrderNo != "") {
            href += "&SaleOrderNo=" + SaleOrderNo;
        } else if (FoctoryNo != "") {
            href += "&FoctoryNo=" + FoctoryNo;
        } else if (StyleNo != "") {
            href += "&StyleNo=" + StyleNo;
        }
        obj.href = href;
}
<a class="btn btn-app" onclick="exportExcel(this)"><i class="fa fa-edit"></i>导出Excel</a>
        /// <summary>
        /// 加工单导出Excel
        /// </summary>
        /// <returns></returns>
        public ActionResult ExportPressingExcel()
        {
            string FoctoryNo = Request.Params["FoctoryNo"];
            string StyleNo = Request.Params["StyleNo"];
            string SaleOrderNo = Request.Params["SaleOrderNo"];

            List<Factory> fList = fService.GetAllFactory();
            List<Factory> aList = new List<Factory>();
            if (fList != null)
            {
                for (int i = 0; i < fList.Count; i++)
                {
                    Factory f = new Factory();
                    f.FactoryId = fList[i].FactoryId;
                    f.FactoryName = fList[i].FactoryName;
                    f.Tel = fList[i].Tel;
                    f.Mobile = fList[i].Mobile;
                    f.MailBox = fList[i].MailBox;
                    f.Addr = fList[i].Addr;

                    aList.Add(f);
                }
            }

            List<Processing> pList = pService.GetExcelProcessing(FoctoryNo, StyleNo, SaleOrderNo);
            List<Processing> rList = new List<Processing>();
            if (pList != null)
            {
                for (int i = 0; i < pList.Count; i++)
                {
                    Processing s = new Processing();
                    s.ProcessingId = pList[i].ProcessingId;
                    s.SaleOrderNo = pList[i].SaleOrderNo;
                    s.StoneOutNo = pList[i].StoneOutNo;
                    s.FactoryId = pList[i].FactoryId;
                    s.ReceiveDate = pList[i].ReceiveDate;
                    s.CustomerManager = pList[i].CustomerManager;
                    s.FoctoryUser = pList[i].FoctoryUser;
                    s.FoctoryNo = pList[i].FoctoryNo;
                    s.StyleNo = pList[i].StyleNo;
                    s.CustomerSc = pList[i].CustomerSc;
                    s.Material = pList[i].Material;
                    s.Requirement = pList[i].Requirement;
                    s.SizeJ = pList[i].SizeJ;
                    switch (pList[i].CompletedStatus)
                    {
                        case "0":
                            s.CompletedStatus = "未完成";
                            break;
                        case "1":
                            s.CompletedStatus = "完成";
                            break;
                        case "2":
                            s.CompletedStatus = "取消";
                            break;
                        default:
                            s.CompletedStatus = "未完成";
                            break;
                    }

                    rList.Add(s);
                }
            }

            DataTable table = new DataTable();
            table.Columns.Add(new DataColumn("工厂单号"));
            table.Columns.Add(new DataColumn("订单编号"));
            table.Columns.Add(new DataColumn("加工厂"));
            table.Columns.Add(new DataColumn("送厂日期"));
            table.Columns.Add(new DataColumn("出库单号"));
            table.Columns.Add(new DataColumn("客户经理"));
            table.Columns.Add(new DataColumn("工厂接收人"));
            table.Columns.Add(new DataColumn("款式编号"));
            table.Columns.Add(new DataColumn("客户手寸"));
            table.Columns.Add(new DataColumn("材质"));
            table.Columns.Add(new DataColumn("刻字要求"));
            table.Columns.Add(new DataColumn("金重"));
            table.Columns.Add(new DataColumn("状态"));

            foreach (var o in rList)
            {
                DataRow row = table.NewRow();
                row["工厂单号"] = o.FoctoryNo;
                row["订单编号"] = o.SaleOrderNo;
                foreach (var item in aList)
                {
                    if (o.FactoryId == item.FactoryId)
                    {
                        row["加工厂"] = item.FactoryName;
                    }
                }
                row["送厂日期"] = o.ReceiveDate;
                row["出库单号"] = o.StoneOutNo;
                row["客户经理"] = o.CustomerManager;
                row["工厂接收人"] = o.FoctoryUser;
                row["款式编号"] = o.StyleNo;
                row["客户手寸"] = o.CustomerSc;
                row["材质"] = o.Material;
                row["刻字要求"] = o.Requirement;
                row["金重"] = o.SizeJ;
                row["状态"] = o.CompletedStatus;
                table.Rows.Add(row);
            }

            MemoryStream MemoryStream = new MemoryStream();
            HSSFWorkbook work = ExcelHelper.CreateExcelByNPOI(table);
            work.Write(MemoryStream);
            return File(MemoryStream.GetBuffer(), "application/ms-excel", "加工单-" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls");
}

 

 

 

--------------------------------------------------------------------------------------------------------- 

转载请记得说明作者和出处哦-.-
作者:KingDuDu
原文出处:https://www.cnblogs.com/kingdudu/articles/4913250.html

---------------------------------------------------------------------------------------------------------

posted @ 2015-10-27 09:41  KingDuDu  阅读(8384)  评论(1编辑  收藏  举报