为了更方便,没基础的伙伴更容易理解,我尽量详细简便 省了很多代码,一步一步的试

自己引入文件

 1. 

html 前端视图代码 Layui的数据绑定 全部代码

@{
Layout = null;
}
<html>
<head>
<meta charset="utf-8">
<title>查询来料清单</title>
<script src="~/Content/新建文本文档.js" type="text/javascript"></script>
<!-- 注意:分页必须引用下面两个文件 且css后加 rel="stylesheet" media="all"-->
<link href="~/Content/layui-v2.4.5/layui/css/layui.css" rel="stylesheet" media="all" />
<link rel="stylesheet" href="~/Content/layui-v2.4.5/layui/css/layui.css" media="all">
<!-- 注意:如果你直接复制所有代码到本地,上述css路径需要改成你本地的 --> <style type="text/css">
.layui-input {
height: 30px;
width: 200px;
}
</style>
</head>
<body>
<script type="text/html" id="toolbarDemo">
<div class="layui-btn-container" style="float:left;">
<button class="layui-btn layui-btn-sm layui-btn-normal" lay-event="Spen">导入清单</button>
</div>
<div class="layui-btn-container" style="float:left;">
<button class="layui-btn layui-btn-sm layui-btn-normal" lay-event="outdata" id="excel">导出Excel</button>
</div>
</script> <table class="layui-hide" id="test" lay-filter="test" lay-size="sm"></table><!--table--> <script src="~/Content/layui-v2.4.5/layui/layui.js"></script>
<!-- 注意:如果你直接复制所有代码到本地,上述js路径需要改成你本地的 --> <script>
$(function () { //----------------------------表格开始----------------------------------
layui.use('table', function () {
var table = layui.table;
//执行一个laydate实例
var tableIns=table.render({
id: 'test',//id容器
elem: '#test',//指定元素
url: '/Left_D/Ji_jian_Load', //数据接收URL地址 ------------------------------------这个地址要换自己的
methord: 'post',
cellMinWidth: ,
page: { layout: ['count'] },//更改分页的组建的位置
height: "full-50", //这里数值越高离上面就越近 数值越低离下面就越近
limits: [, , , ], //显示分页的条数
limit: , //默认显示条数
fitColumns: true, //表格自动适应屏幕
even: false, //隔行背景是否显示
toolbar: '',//开启表格头部工具栏区域 toolbar: '#toolbarDemo' //指向自定义工具栏模板选择器toolbar: '<div>xxx</div>' //直接传入工具栏模板字符toolbar: true //仅开启工具栏,不显示左侧模板toolbar: 'default' //让工具栏左侧显示默认的内置模板
title: '来料清单',
toolbar: '#toolbarDemo', //开启头部工具
defaultToolbar: ['filter'], //工具栏右侧的图标
cols: [[
{ type: 'checkbox', title: '急检', width: , align: "center" },
{ field: 'ID', title: 'ID', hide: "true", width: , align: "center", sort: "true" },
{ type: 'numbers', title: '序号' , width: , align: "center" },
{ field: 'LH001', title: '品号' , width: , align: "center", sort: "true" }, //sort是否允许排序
{ field: 'LH002', title: '品名' , width: , align: "center" },
{ field: 'LH003', title: '规格' , width: , align: "center" },
{ field: 'LH004', title: '请购-单别-单号-序号', width: , align: "center" },
]], done: function (res, curr, count) { //res即为你接口返回的信息 //得到当前页码curr //得到数据总量count
$("[data-field='ID']").css('display', 'none'); //隐藏ID列 ,ui里隐藏失效
}
}); //批量导入
table.on('toolbar(test)', function (obj) {
var object1 = []
var arr;
var checkStatus = table.checkStatus(obj.config.id);
switch (obj.event) {//批量导出功能
case 'outdata':
debugger;
var data = checkStatus.data;
if (data != "" && data != null) {
for (var i = ; i < data.length; i++) { //循环拿到选择的数据放进数组
var id = data[i].ID;
object1.push(id);
arr = object1.join(','); //用逗号将数据隔开
}
$.ajax({
url: "/Left_D/OutData1",
type: "post", //提交方式
data: {
arr: arr
},
success: function (data) {
window.location.href = "/Left_D/DataExcel1"; //转到导出方法
}
});
}
else {
layer.msg('请选择导出的数据');
return;
}
};
});
});</script>
</body>
</html>

前端效果图

using System.Collections.Generic;
using System.IO;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;

2.

控制器后台代码 不懂引用文件在下面第3点

 //批量导出
[HttpPost]
public void OutData1()
{
string time = Convert.ToDateTime(DateTime.Now).ToString();
string[] splist;
string danhao = Request["arr"];
splist = null;
splist = danhao.Split(','); List<L_Ji_jian> data = bll.OutData1(splist); //数据源拿到数据 XSSFWorkbook workbook = new XSSFWorkbook(); //创建一个excel
XSSFSheet sheet = (XSSFSheet)workbook.CreateSheet(); //创建一个sheet IRow frow0 = sheet.CreateRow(); // 添加一行(一般第一行是表头)
frow0.CreateCell().SetCellValue("品号"); //表头内容
frow0.CreateCell().SetCellValue("品名");
frow0.CreateCell().SetCellValue("规格");
frow0.CreateCell().SetCellValue("请购单别单号序号");
for (int i = ; i < data.Count; i++) //循环添加list中的内容放到表格里
{
IRow row = sheet.CreateRow(i + ); //之所以从i+1开始 因为第一行已经有表头了
row.CreateCell().SetCellValue(data[i].LH001);
row.CreateCell().SetCellValue(data[i].LH002);
row.CreateCell().SetCellValue(data[i].LH003);
row.CreateCell().SetCellValue(data[i].LH004); } var path = System.AppDomain.CurrentDomain.BaseDirectory; //获得项目的基目录 var Path = System.IO.Path.Combine(path, @"Uploads\Excel\\"); //进到基目录录找“Uploadss->Excel”文件夹 if (!System.IO.Directory.Exists(Path)) //判断是否有该文件夹
System.IO.Directory.CreateDirectory(Path); //如果没有在Uploads文件夹下创建文件夹Excel
string saveFileName = Path + "\\" + "来料清单信息表" + ".xlsx"; //路径+表名+文件类型
try
{
using (FileStream fs = new FileStream(saveFileName, FileMode.Create, FileAccess.Write))
{
workbook.Write(fs); //写入文件
workbook.Close(); //关闭
}
}
catch (Exception ex)
{
Response.Write("<script>alert('错误信息:" + ex.Message + "');</script>");
}
}
 //调用浏览器导出
public void DataExcel1(object sender, EventArgs e)
{
string fileName = "来料清单信息表" + ".xlsx";//客户端保存的文件名
var path = System.AppDomain.CurrentDomain.BaseDirectory; //获得项目的基目录
string sering = path + "\\Uploads\\Excel\\" + fileName; //自定义服务器路径 + 文件名
//以字符流的形式下载文件
FileStream fs = new FileStream(sering, FileMode.Open);
byte[] bytes = new byte[(int)fs.Length];
fs.Read(bytes, , bytes.Length);
fs.Close();
Response.ContentType = "application/octet-stream";
//通知浏览器下载文件而不是打开
Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
Response.BinaryWrite(bytes);
Response.Flush();
Response.End();
}

项目文件在控制器这层 新建文件夹Uploade--》Excel ,如果没有代码自己创建

3.

基本就完成了,点击导出调用浏览器在浏览器下载你服务器上的Excel文件

layui + mvc + ajax 导出Excel功能的更多相关文章

  1. .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)

    .Net MVC  导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构)   public cl ...

  2. Atitit.导出excel功能的设计 与解决方案

    Atitit.导出excel功能的设计 与解决方案 1.1. 项目起源于背景1 1.2. Js  jquery方案(推荐)jquery.table2excel1 1.3. 服务器方案2 1.4. 详细 ...

  3. 项目笔记:导出Excel功能

    1.前台这块: var ids=""; $.post("${basePath}/assets/unRegDeviceAction_getDeviceIds.do" ...

  4. 项目笔记:导出Excel功能分sheet页插入数据

    导出Excel功能分sheet页处理数据: /*导出EXCEL*/ public void createExcel() { log.info("导出Excel功能已经启动-BEGIN&quo ...

  5. vue项目导出EXCEL功能

    因为一些原因导出EXCEL功能必须前端来做,所以就研究了一下,在网上也找了一些文章来看,有一些不完整,我做完了就记录下来,供大家参考: 1.首先先安装依赖: npm install file-save ...

  6. Vue通过Blob对象实现导出Excel功能

    不同的项目有不同的导出需求,有些只导出当前所显示结果页面的表格进入excel,这个时候就有很多插件,比如vue-json-excel或者是Blob.js+Export2Excel.js来实现导出Exc ...

  7. dataTables的导出Excel功能

    Datatables它是一款基于jQuery表格插件,钟情于它操作dom的灵活.做后台的同学想必使用它能事半功倍,而且交互强.容易扩展. 我也是最近要做公司后台界面,表格涉及的很多,所以考虑使用DT, ...

  8. asp.net core web的导入导出excel功能

    这里主要记录下asp.net core web页面上进行导入导出excel的操作. 主要是导入,因为现在使用的很多前端框架(例如kendo ui)本身就有导出的功能. 这里使用到EPPlus.Core ...

  9. ajax导出excel文件并增加等待动画效果

    html: <button class="btn btn-default" onclick="logToExcel('{:url('userLogToExcel', ...

随机推荐

  1. python基础(5):格式化输出、基本运算符、编码问题

    1. 格式化输出 现在有以下需求,让⽤户输入name, age, job,hobby 然后输出如下所⽰: ------------ info of Alex Li ----------- Name : ...

  2. Java技巧——比较两个日期相差的天数

    Java技巧——比较两个日期相差的天数 摘要:本文主要记录了在Java里面如何判断两个日期相差的天数. 判断两个Date类型的日期之间的天数 通过计算毫秒数判断: public static void ...

  3. 压测应用服务对RabbitMQ消息的消费能力--实践脚本

    最近运维跟我反馈我负责的应用服务线上监控到消费RabbitMQ消息队列过慢,目前只有20左右,监控平台会有消息积压的告警. 开发修改了一版应用服务的版本,提交给我做压测验证. 之前没有做过消息中间件的 ...

  4. java基础第十六篇之多线程

    1:线程的概念 进程(任务):一个正在运行的程序 进程的调度:CPU来决定什么时候该运行哪个进程 (时间片轮流法) 线程在一个应用程序中,同时,有多个不同的执行路径,是进程中的实际运作单位. 好处是提 ...

  5. Add a Class from the Business Class Library 从业务类库添加类 (XPO)

    In this lesson, you will learn how to use business classes from the Business Class Library as is. Fo ...

  6. Dynamics CRM 中Web API中的深度创建(Deep Insert)

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  7. 用BAPI_ACC_DOCUMENT_POST过账生成凭证

    根据前台需要输入参数,在bapi里面传值,不同业务所需参数不同. dome1: "bapi结构赋值     LOOP AT lt_item INTO lw_item.       wa_do ...

  8. 爬虫---PyQuert简介

    今天写一篇最近刚学习的一个第3方库pyquery,pyquery比bs4,lxml更强大的一个网页解析工具. 什么是pyQuery Pyquery是python的第3方库,PyQuery库也是一个非常 ...

  9. for循环结构

    循环结构: 在程序当中总有一些需要反复/重复的执行的代码,假设没有循环结构,那么这段需要重复知心的需要重复执行的代码自然是需要重复编写的,代码无法得到重复使用.所以多数变成语言都是支持循环结构的.将来 ...

  10. Div转为Canvas简直不要太好玩~~~

    html2canvas库 今天发现了一个神奇的玩意,简直不要太好玩~~ 用canvas做动画是很难,但是div能比canvas简单不少,只是因为canvas中不能操作Dom元素 这款神器,可以直接将D ...