只依赖ajax的文件上传js工具
1、效果如下
1.1 对应上传成功的如果再次点击不会重复上传,
1.2 图示操作按钮为layui的字体图标,对于通用版则按钮为文字,可以自行进行修改,或自定义操作按钮
1.3 纯图片
1.4 文件加图片,图片会显示为图片,文件则以图示的第二、三的样子的默认图片显示
2、使用示例
2.1 声明上传对象
其中$("#files")为包裹元素
var fuhCommon = new FileUploadHelperCommon($("#files"));//
2.2 初始化渲染参数
//初始要显示的数据,例如查看和编辑时可能有已存在的数据
var filesDatas = [];
filesDatas.push({
"path":"xxx"
,"fullPath":"http://localhost:8080/base/static/images/111.jpg"
,"name":"123"
,"fileType":"1"
});
filesDatas.push({
"path":"xxx"
,"fullPath":"http://localhost:8080/base/static/js/FileUploadHelper.js"
,"name":"123"
,"fileType":"2"
});
//初始化配置信息
fuhCommon.init({
"datas":filesDatas
,showDeleteBtn:true
,showDownBtn:true
,showPreviewBtn:true
,fileType:0//默认 0 各种文件类型 1:图片类型(只能选择图片)
,fileNumber:100//可以选择的文件数量
,addFile:true
,buttons:{
"info":{//自定义回调按钮
"name":"",
"class":"layui-icon layui-icon-tips icon-white",
"callback":function(data){
alert(data);
console.log(data);
}
}
}
});
2.3 执行上传动作
fuhCommon.upload({
"url":"http://localhost:8080/base/a/sys/importFile/ajax"
,"data":{
}
,"dataHandle":function(params){//上传接口调用成功回调后需要将原始返回数据处理为内部可读数据
//上传接口请求完成返回原始数据
var data = params.data;
var code = data.code;
//返回的上传后文件数组信息
var fileInfos = data.data;
//这里需要对数据进行处理
for(var index=0; index
3、代码
/**
* 文件上传辅助工具
*
* 只依赖jquery版本
*
* $ele 包裹元素的jquery对象
*
* 改进版1.1
* 1、可以指定只上传图片
* 2、可以指定限定选择文件数量
*
* demo
*
* fuh = new FileUploadHelper($("#testFUH"));
fuh.init({
//初始显示文件数据列表
"datas":[{
path:"122323",
fullPath:"",
name:"测试文件",
fileType:"1" //文件类型 1图片
},{
path:"122323",
fullPath:"",
name:"测试文件",
fileType:"2" //文件类型 1图片
},{
path:"122323",
fullPath:"",
name:"测试文件",
fileType:"3" //文件类型 1图片
},{
path:"122323",
fullPath:"",
name:"测试文件",
fileType:"4" //文件类型 1图片
},{
path:"122323",
fullPath:"",
name:"测试文件",
fileType:"5" //文件类型 1图片
}]
,showDeleteBtn:true//是否显示删除按钮
,showDownBtn:true//是否显示下载按钮
,showPreviewBtn:true//是否显示预览按钮
,hideOptionButtons:true//加载是否隐藏操作按钮栏,如果是true,那么会隐藏操作栏,鼠标停留图片上时弹出。如果是false,则操作栏一直显示
,fileType:0//默认 0 各种文件类型 1:图片类型(只能选择图片)
,fileNumber:1//可以选择的文件数量
,addFile:true//是否可以继续添加文件,如果只是查看,那么这里设置为false,如果是编辑,则这里设置为true
,buttons:{//自定义按钮
"info":{
//1、这里可以定义字体图片的class,将name置为空则显示图标
//2、不使用字体图标,则名字不为空
"name":"",
"class":"layui-icon layui-icon-tips icon-white",
"callback":function(data){
alert(data);
}
}
}
});
*
* fuh.upload({
*
* "url":"https://ssss/ss/fileUpload"
* ,"data":{}
* ,"callback":function(data){//所有上传动作结束回调
*
* //是否所有文件均上传成功
* var allOk = data.allOk;
* //所有上传文件列表
* var datas = data.datas;
* //所有文件item页面元素
* var eles = data.eles;
* //所有页面索引对应数据
* var pathInfos = data.pathInfos;
* }
* ,"askError":function(msg){//上传接口调用失败回调
*
* //请求失败回调
*
* }
* ,"dataHandle":function(params){//上传接口请求成功回调
//上传接口请求完成返回原始数据
var data = params.data;
//返回的上传后文件数组信息
var fileInfos = xxx;
//这里需要对数据进行处理
for(var index=0; index选择文件
'
'
';
var _box = document.createElement("div");
_box.style.cssText = "width:100%;";
//上传成功返回数据
_this.pathInfos = {};
//当前最大索引值
_this.maxIndex = -1;
/**
config
{
datas:[{//初始化数据
name:文件名称
path:文件数据库存储地址
fullPath:完整文件路径,即下载文件路径
fileType://文件类型 1:图片
}],
,showDeleteBtn:true//是否显示删除按钮
,showDownBtn:true//是否显示下载按钮
,showPreviewBtn:true//是否显示预览按钮
,hideOptionButtons:true//加载是否隐藏操作按钮栏
,fileType:0//默认 0 各种文件类型 1:图片类型(只能选择图片)
,fileNumber:1//可以选择的文件数量
,addFile:true//是否可以继续添加文件
,buttons:{//自定义按钮
"info":{
//1、这里可以定义字体图片的class,将name置为空则显示图标
//2、不使用字体图标,则名字不为空
"name":"",
"class":"layui-icon layui-icon-tips icon-white",
"callback":function(data){
alert(data);
}
}
}
,imageHeight://如果是图片类型的话,图片的高度,默认170px
}
**/
this.init = function(config){
if(!config){
config = {};
}
var datas = config.datas;
if(!datas){
datas = [];
}
var buttons = config.buttons;
if(!buttons){
buttons = {};
}
var fileType = config.fileType;
var addFile = config.addFile;
var imageHeight = config.imageHeight;
var fileNumber = config.fileNumber;
_hideOptionButtons = config.hideOptionButtons;
if(fileNumber){
_fileNumber = fileNumber;
}
_buttons = buttons;
_fileType = fileType;
_$ele.append(_box);
for(var index in datas){
var data = datas[index];
var name = data.name;
var path = data.path;
var fullPath = data.fullPath;
var fileType = data.fileType;
//文件类型
if(fileType == undefined){
fileType = 0;
}
config.fileType = fileType;
//文件名称
config.name = data.name;
//页面元素索引
var pathIndex = updatePathIndex({
"optionType":0
});
config.pathIndex = pathIndex;
_this.pathInfos[pathIndex] = data;
config.buttons = buttons;
config.fullPath = fullPath;
config.filePath = path;
config.initDataIndex = index;
//添加页面元素
$(_box).append(getFileItem(config));
//初始化点击事件
initEvent(config.pathIndex);
}
//添加 添加文件按钮
if(!addFile){
return;
}
$(_box).append(_addItem);
addButtonHideJudge()
//声明添加按钮点击事件
$(_box).find("[jq_sign=addFile]").click(function(){
var preItem = $(this).prev();
if(preItem.attr("jq_chooseFile") == "chooseFile"){//如果前面的为选择文件元素,则直接调起选择文件事件
preItem.find("input").click();
}else{//前面的元素问已经选择过的文件元素,则添加新的选择元素
var pathIndex = updatePathIndex({
"optionType":0
});
$(this).before(getFileItem({"needUpload":true,"pathIndex":pathIndex,chooseFile:true,showDeleteBtn:true,hide:true}));
initEvent(pathIndex);
preItem = $(this).prev();
preItem.find("input").click();
preItem.find("input").change(function(){
fileChange($(this),function(name){
var originName = name;
if(name.length>=8){
var lastNameIndex = name.lastIndexOf(".");
var lastName = name.substr(lastNameIndex);
var dx = name.length - 8 - lastName.length;
name = name.substr(0,lastNameIndex-dx)+"..."+lastName;
}
preItem.find("[jq_sign=fileName]").text(name);
preItem.find("[jq_sign=fileName]").attr("jq_fuh_fileName",originName);
preItem.show().attr("jq_chooseFile","");
addButtonHideJudge();
})
});
}
});
}
/**
* 上传事件
* 参数
* {
* url str //请求上传url
* data json //请求上传参数
* callback function 上传完成回调事件
* error function 请求失败回调
* dataHandle function 请求结果数据处理方法
* }
*
* 例子
* fuh.upload({
*
* "url":"https://ssss/ss/fileUpload"
* ,"data":{}
* ,"callback":function(data){
*
* //是否所有文件均上传成功
* var allOk = data.allOk;
* //所有上传文件列表
* var datas = data.datas;
* //所有文件item页面元素
* var eles = data.eles;
* //所有页面索引对应数据
* var pathInfos = data.pathInfos;
* }
* ,"askError":function(msg){
*
* //请求失败回调
*
* }
* ,"dataHandle":function(params){
*
* //上传接口请求完成返回原始数据
* var data = params.data;
*
* //返回的上传后文件数组信息
* var fileInfos = xxx;
* var code = xx;
*
* //这里需要对数据进行处理
* for(var index=0; index
',type:1}); */
/*var json={
"data": [ //相册包含的图片,数组格式
{
"src": url, //原图地址
"thumb": url //缩略图地址
}
]
}*/
var ele = '
';
$("body").prepend(ele);
}
//更新元素索引
/**
*/
var updatePathIndex = function(params){
//optionType 0-添加 1-删除
var optionType = params.optionType;
//页面元素索引
var pathIndex = params.pathIndex;
var maxIndex = _this.maxIndex;
if(maxIndex == undefined){
maxIndex = -1;
}
if(optionType == 1){//删除
//移除
delete _this.pathInfos[pathIndex];
}else{//加入
maxIndex += 1;
}
_this.maxIndex = maxIndex;
return maxIndex;
}
//判断并对添加文件按钮进行显示和隐藏
var addButtonHideJudge = function(){
var addButtonObj = $(_box).find("[jq_sign=addFile]");
if(_this.currNumber >= _fileNumber){
if(addButtonObj){
addButtonObj.hide()
};
return true;
}else{
if(addButtonObj){
addButtonObj.show();
}
return false;
};
}
//初始化事件
var initEvent = function(pathIndex){
var box = $(_box).find("[jq_pathIndex="+pathIndex+"]");
var fullpath = box.attr("jq_fullPath");
var path = box.attr("jq_filePath");
var data = {
"fullpath":fullpath,
"path":path
}
//下载事件
box.find("[jq_sign=fileItem_event_download]").click();
//删除事件
box.find("[jq_sign=fileItem_event_delete]").click(function(){
box.remove();
updatePathIndex({
"optionType":1
,"pathIndex":pathIndex
});
addButtonHideJudge();
});
//预览事件
box.find("[jq_sign=fileItem_event_preview]").click(function(){
_this.showImage({
"url":fullpath
});
});
//操作按钮显示和隐藏
if(_hideOptionButtons){
box.mouseover(function(){
box.find("[jq_sign=fileItem_option_buttons]").show();
});
box.mouseout(function(){
var fun_failItem = box.find("[jq_sign=fun_failItem]");
if(fun_failItem.length > 0){
//该元素上传失败了,不进行隐藏
}else
box.find("[jq_sign=fileItem_option_buttons]").hide();
});
}
/*box.find("[jq_sign=fileItem_option_buttons]").mouseover(function(){
box.find("[jq_sign=fileItem_option_buttons]").show();
});
box.find("[jq_sign=fileItem_option_buttons]").mouseout(function(){
box.find("[jq_sign=fileItem_option_buttons]").hide();
});*/
//自定义事件
for(var key in _buttons){
var callback = _buttons[key].callback;
box.find("[jq_sign=fileItem_event_"+key+"]").click(function(){
callback(data);
});
}
}
//監聽reader文件讀取完成事件
_reader.onload = function(e) {
var fileObj = $(_box).find("input[type=file][jq_choose_image=true]");
var fileName = fileObj[0].files[0].name;
fileObj.parent().find("img").attr("src",e.target.result);
fileObj.attr("jq_choose_image","false");
_fileChangeCallback(fileName);
};
//文件改变
var fileChange = function(obj,callback){
var file = $(obj)[0].files[0];
var fileType = file.type.toLocaleLowerCase();
if(_fileType == 1){//只能上传图片类型文件
if(fileType !== 'image/jpeg' && fileType !== 'image/png' && fileType != 'image/gif'){
layer.msg("请选择图片");
return;
}
_reader.readAsDataURL($(obj)[0].files[0]);
$(obj).attr("jq_choose_image","true");
_fileChangeCallback = callback;
}else{
if(fileType == 'image/jpeg' || fileType == 'image/png' || fileType == 'image/gif'){
//文件是图片
_reader.readAsDataURL($(obj)[0].files[0]);
$(obj).attr("jq_choose_image","true");
_fileChangeCallback = callback;
return;
}
if(callback){
callback(file.name);
}
}
}
/**
* 获取元素item
* {
* name 文件名称
* fullPath 改文件的完整访问路径
* showDownBtn true/false是否显示下载按钮
* fileType://文件类型 1 图片
* showDeleteBtn true/false是否显示移除按钮
* buttons 自定义按钮
* needUpload 是否需要上传的元素
* chooseFile 该元素是否是还没有选择文件
* hide 该元素是否隐藏
* pathIndex 该元素的地址索引
* initDataIndex 如果是初始化数据,需要传入初始化数据的index
* }
*/
var getFileItem = function(config){
if(!config){
config = {};
}
var name = config.name;
var buttons = config.buttons;
var needUpload = "";
if(config.needUpload){
needUpload = 'jq_needUpload="ture"';
}
var chooseFile = "";
if(config.chooseFile){
chooseFile = 'jq_chooseFile="chooseFile"';
}
var hide = "";
if(config.hide){
hide = "display:none;";
}
var pathIndex = 0;
if(config.pathIndex){
pathIndex = config.pathIndex;
}
var fullPath = config.fullPath;
if(!fullPath){
fullPath = "";
}
var filePath = config.filePath;
if(!filePath){
filePath = "";
}
var imageHeight = config.imageHeight;
if(imageHeight){
_imageHeight = imageHeight;
}
var initDataIndex = config.initDataIndex;
if(initDataIndex == undefined || initDataIndex == ""){
initDataIndex = -1;
}
var fileType = config.fileType;
//操作按钮样式
var optionButtonStyle="color:white;cursor:pointer;float:left;margin-left: 10px;padding:0 6px 0 6px;text-align: center;vertical-align: middle;line-height: 20px;margin: 5px;"
var fileItem = '
'
//option
var fileItem_option_buttons_display_style = "";
if(_hideOptionButtons){
fileItem_option_buttons_display_style = "display:none;";
}
fileItem +='
';
fileItem +='
';
//删除
if(config.showDeleteBtn){
fileItem +='
'
+'删除
'
}
//下载
if(config.showDownBtn){
fileItem +='
'
+'下载 '
}
//预览
if(config.showPreviewBtn && fileType == 1){
//图片类型才可以这种预览
fileItem +='
'
+'预览
'
}
for(var key in buttons){
var buttonName = buttons[key].name;
var buttonClass = buttons[key].class;
fileItem +='
'
+buttonName+'
'
}
fileItem +='
';
//option结束
var imageSrc = fullPath;
//判断是否是图片
if(fileType != 1){
//如果不是图片则显示普通文件图片
imageSrc = nomalFileImage;
}
fileItem += '
'
+'
';
//文件名称
fileItem += '
'+name+'
';
if(config.needUpload){
fileItem += '
';
}
fileItem +='
';
return fileItem;
}
/**
* 最终返回的回调
*/
var callback = function(pCallback,upFileOk){
var allDatas = getAllDatas();
//是否全部文件上传成功
allDatas.allOk = upFileOk;
if(pCallback){
pCallback(allDatas);
}
}
/**
* 获取完整的上传的文件信息
*/
var getAllDatas = function(){
var items = {};
//返回的数据
var datas = [];
//页面元素
var eles = {};
var uploadIndex = 0;
var datasIndex = 0;
for(var pathIndex in _this.pathInfos){
var box = $(_box).find("[jq_pathIndex="+pathIndex+"]");
var initDataIndex = box.attr("jq_fuh_initDataIndex");
var data = _this.pathInfos[pathIndex];
//如果初始索引不为-1,表示这是初始的数据
if(initDataIndex != -1){
//初始的数据
data.beUploadData = false;
datas[datasIndex++] = data;
}else{
//上传的数据
data.beUploadData = true;
datas[datasIndex++] = data;
}
eles[pathIndex] = box;
}
items.datas = datas;
items.pathInfos = _this.pathInfos;
items.eles = eles;
return items;
}
/**
* 对上传失败文件处理
*/
var uploadedFailHandle = function(item){
item.find("[jq_sign=fileItem_option_buttons]").show();
item.find("[jq_sign=fileItem_option_buttons]").css({"background":"rgb(196 66 66 / 62%)"});
var fun_failItem = item.find("[jq_sign=fileItem_option_buttons]").find("[jq_sign=fun_failItem]");
if(fun_failItem == undefined || fun_failItem.length == 0){
item.find("[jq_sign=fileItem_option_buttons]").append('
上传失败
');
}
}
/**
* 对上传成功文件处理
*/
var uploadedSuccessHandle = function(item){
item.find("[jq_sign=fileItem_option_buttons]").show();
item.find("[jq_sign=fileItem_option_buttons]").css({"background":"rgb(164 255 188 / 62%)"});
var fun_failItem = item.find("[jq_sign=fileItem_option_buttons]").find("[jq_sign=fun_failItem]");
if(fun_failItem != undefined){
fun_failItem.remove();
}
}
var noPicImage = "";
var nomalFileImage = "";
}