基于BootStrap的initupload()实现Excel上传和获取excel中的数据
简单说明:后边要做exl解析(还没做呢),所以先有一个excel的的上传以及获取excel中的数据,展示出来。
代码:
//html代码
<div class="btn-group">
<button class="btn sbold green" id="" onclick="initUpload('excelFile','/vraxx/rightAxx/upload');">
<span class="ladda-label">导入权益</span>
</button>
</div>
<div class="modal-body">
<div class="row">
<div class="form-group">
<div id="res_tree">
<input id="excelFile" name="excelFile" type="file" multiple="multiple" accept=".xls,.xlsx"/>
</div>
</div>
</div>
</div>
//js代码
function initUpload(ctrlName, uploadUrl) {
var control = $('#' + ctrlName);
//延时可以去掉的,不影响
clickTimer = window.setTimeout(function(){
control.fileinput({
language: 'zh', //设置语言
uploadUrl: rootPath+uploadUrl, //上传的地址
uploadAsync: false, //默认异步上传
showCaption: true,//是否显示标题
showUpload: true, //是否显示上传按钮
browseClass: "btn btn-primary", //按钮样式
allowedFileExtensions: ["xls", "xlsx"], //接收的文件后缀
maxFileCount: 0,//最大上传文件数限制
previewFileIcon: '<i class="glyphicon glyphicon-file"></i>',
showPreview: true, //是否显示预览
previewFileIconSettings: {
'docx': '<i ass="fa fa-file-word-o text-primary"></i>',
'xlsx': '<i class="fa fa-file-excel-o text-success"></i>',
'xls': '<i class="fa fa-file-excel-o text-success"></i>',
'pptx': '<i class="fa fa-file-powerpoint-o text-danger"></i>',
'jpg': '<i class="fa fa-file-photo-o text-warning"></i>',
'pdf': '<i class="fa fa-file-archive-o text-muted"></i>',
'zip': '<i class="fa fa-file-archive-o text-muted"></i>',
},
//黄色部分是业务代码,可以删去
//蓝色部分是和excel文件相关的固定写法
//div_startimport是插件里的某个元素
uploadExtraData: function () {
var rightCode=$("#rightCode").val();
if(rightCode == null){
layer.alert("请选取XX号进行上传")
var oTable = new TableInit();
oTable.Init(data);
$("#div_startimport").show();
}else {
var extraValue = "test";
return {"excelType": extraValue};
}
}
});
//后边两句也可以去掉,我自己的一个弹出样式
$('#res_tree').jstree("deselect_all",true);
$('#responsive_1').modal();
}, 300); } $("#excelFile").on("filebatchuploadsuccess", function (event, data, previewId, index) {
//样式可删去
$("#responsive_1").modal('hide');
//业务代码可删除
var rightCode=$("#rightCode").val();
//很关键 获取excel里的数据转为json
var obj=JSON.stringify(data.response);
//后边是通过html动态加载,把数据传到后台
//换成一般的ajax也是可以的,灵活一点
var html = $("#topli").html();
var tb = $("#loadhtml");
var searchServPath = "/vraxx/rightAxx/toexcel";
tb.html(CommnUtil.loadingImg());
tb.load(rootPath + searchServPath,{excelJson:obj,rightCode:rightCode}, function () {
/** 动态构建内容页面的 path 连接 */
html += '<li data-path="' + searchServPath + '"><i class="fa fa-circle"></i><a href="javascript:void(0)">XX导入</a></li>';
$("#topli").html(html);
});
});
//后台java代码
@RequestMapping(value = "/upload", method = RequestMethod.POST)
@ResponseBody
private List<List<String>> importExcel(@RequestParam(value = "excelFile", required = false) MultipartFile[] file, HttpServletRequest request) {
ModelMap map=new ModelMap();
List<List<String>> list =new ArrayList<>();
try {
MultipartRequest multipartRequest=(MultipartRequest) request;
List<MultipartFile> files = ((MultipartHttpServletRequest) request)
.getFiles("excelFile");
for (MultipartFile mufile :files){
List<List<String>> datas = ExcelUtil.readXlsx(mufile.getInputStream(),mufile.getOriginalFilename());
list.addAll(datas);
}
} catch (Exception e) {
e.printStackTrace();
logger.error("导入失败");
}
return list;
} @RequestMapping("/toexcel")
public String toexcel(String excelJson,String rightCode,ModelMap map) throws Exception{
List<List<String>> listString= JSONArray.fromObject(excelJson);
List<VraxxTemporary> rightList = new ArrayList<>();
/**
* 对listString增强for循环取数据放到rightList的那坨代码就不贴了
*/
map.addAttribute("rightList", rightList);
return VIEW_PATH+"/detail";//跳转到数据展示页
}
说明:网上有很多关于bootstrap fileupload的使用介绍,但是很多都不太好使,我做这个试了好久才成功,拿出来分享给大家。
基于BootStrap的initupload()实现Excel上传和获取excel中的数据的更多相关文章
- MVC4中基于bootstrap和HTML5的图片上传Jquery自定义控件
		
场景:mvc4中上传图片,批量上传,上传前浏览,操作.图片进度条. 解决:自定义jquery控件 没有解决:非图片上传时,会有浏览样式的问题; 解决方案; 1.样式 – bootstrap 的css和 ...
 - 通过form表单上传文件获取后台传来的数据
		
小伙伴是不是遇到过这样的问题,通过submit提交form表单的时候,不知怎么获取后台传来的返回值.有的小伙伴就会说你不会发送ajax,其实也会.假如提交的form表单中含有文件,怎么办? 步骤1:想 ...
 - from表单实现无跳转上传文件,接收页面后台数据
		
实现无跳转发送表单数据.文件,并能接收后台返回的数据. 主要技术要点: 1.form表单添加target属性,指定一个iframme的name:form表单提交后在iframe内嵌窗口接受响应,主页面 ...
 - 基于thinkphp5的Excel上传
		
涉及知识点: thinkphp5.0: excel上传: mysql建立新表(基本的create语句): mysql ignore(避免重复插入): 主要功能: 通过在视图中上传excel文件,在my ...
 - Resumable.js – 基于 HTML5 File API 的文件上传
		
Resumable.js 是一个 JavaScript 库,通过 HTML5 文件 API 提供,稳定和可恢复的批量上传功能.在上传大文件的时候通过每个文件分割成小块,每块在上传失败的时候,上传会不断 ...
 - 利用Bootstrap简单实现一个文件上传进度条
		
© 版权声明:本文为博主原创文章,转载请注明出处 说明: 1. 使用commons-fileupload.jar实现文件上传及进度监听 2. 使用bootstrap的进度条进行页面显示 3. 因为进度 ...
 - 基于h5的图片无刷新上传(uploadifive)
		
基于h5的图片无刷新上传(uploadifive) uploadifive简介 了解uploadify之前,首先了解来一下什么是uploadify,uploadfy官网,uploadify和uploa ...
 - excel上传和下载
		
需要注意的地方: 1.js构造表单并提交 2.js中文传参encodeURI(encodeURI("中文")),action接收并转换value = URLDecoder.deco ...
 - IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗
		
前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ...
 
随机推荐
- Shell命令-文件及目录操作之cp、find
			
文件及目录操作 - cp.find 1.cp:复制文件或目录 cp命令的功能说明 cp命令用于复制文件或目录. cp命令的语法格式 cp [OPTION]... SOURCE... DIRECTORY ...
 - Python——高阶函数——map filter zip
			
一.map函数 1.作用:它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 2.实例 def f(x): return x* ...
 - 修改host,上github
			
操作如下: 1.http://ping.chinaz.com/ 搜索github.com 海外ip,其实能找到的就两个;然后再搜gist.github.com 海外ip,也是两个. 192.30.25 ...
 - 开篇python
			
测试代码 #!/usr/bin/env python # -*- coding: UTF-8 -*- import os import sys print(os.getcwd) print(sys.v ...
 - 为什么要写 tf.Graph().as_default()
			
首先,去tensorflow官网API上查询 tf.Graph() 会看到如下图所示的内容: 总体含义是说: tf.Graph() 表示实例化了一个类,一个用于 tensorflow 计算和表示用的数 ...
 - 洛谷P1233 木棍加工题解 LIS
			
突然发现自己把原来学的LIS都忘完了,正好碰见这一道题.|-_-| \(LIS\),也就是最长上升子序列,也就是序列中元素严格单调递增,这个东西有\(n^{2}\)和\(nlog_{2}n\)两种算法 ...
 - (二分查找 拓展) leetcode 34. Find First and Last Position of Element in Sorted Array && lintcode 61. Search for a Range
			
Given an array of integers nums sorted in ascending order, find the starting and ending position of ...
 - bootstrap学习: 折叠插件和面板
			
bootstrap提供了面板排版工具和折叠插件,能够用来实现新闻列表.留言板.博客分块等: 1.折叠插件: <a data-toggle="collapse" data-ta ...
 - 老男孩Python全栈学习 S9 日常作业 006
			
1.使用循环打印以下效果: 1: * ** *** **** ***** 2: ***** **** *** ** * 3: * *** ***** ******* ********* for i i ...
 - C++回顾day03---<异常>
			
一:传统错误处理机制(C中通过函数返回来处理) int CalcRes(int n, int m, char ch, int& res) { ; switch (ch) { case '+': ...