AngularJS+Bootstrap实现多文件上传与管理
|
最近一个项目中需要实现多文件上传与管理,而项目是基于bootstrap开发的,所以查了一些bootstrap文件上传插件,最后发现还是bootstrap-fileinput最美观,该插件可以实现多文件的上传与管理(插件官方地址:http://plugins.krajee.com/file-input),具体的效果如下: nbsp; (bootstrap-fileinput不局限于图片上传,也可以实现文件上传,但图片的缩略图容易辨识,这里就以图片上传为例) nbsp;该插件基本的操作可以参考:JS文件上传神器bootstrap fileinput详解,本文主要针对多文件管理。nbsp; 在讲该插件如何使用前,先跟大家讲一下项目中关于图片管理的需求: 1、可以上传多个图片 2、只有当点击保存按钮时,图片信息才保存至数据库 3、可以加载已经保存到数据库的图片信息,并提供删除功能nbsp; 因此,我们可以规定几个文件状态: 已选择:已经放入到插件中,但还没有上传到服务器。如上图中第3个图片,该图片下方有上传按钮。 已上传:已经上传到服务器,但图片信息没有保存到数据库。如上图中第2个图片,该图片下方有100%的进度条。 已保存:图片信息已经保存至数据库的图片,如上图中第1张图,这些图片下方有删除按钮,点击删除时会将图片信息从数据库中删除。nbsp; 一、引入必要文件 lt;link href="lt;%=path%gt;/static/css/bootstrap-3.3.5/bootstrap.min.css" rel="stylesheet"gt; lt;link href="lt;%=path%gt;/static/css/bootstrap-3.3.5/fileinput.css" rel="stylesheet"gt; lt;script src="lt;%=path%gt;/static/js/jquery-1.11.3.js"gt;lt;/scriptgt; lt;script src="lt;%=path%gt;/static/js/angularjs-1.3.9/angular.min.js"gt;lt;/scriptgt; lt;script src="lt;%=path%gt;/static/js/bootstrap-3.3.5/bootstrap.min.js"gt;lt;/scriptgt; lt;script src="lt;%=path%gt;/static/js/bootstrap-3.3.5/fileinput.js"gt;lt;/scriptgt; lt;script src="lt;%=path%gt;/static/js/bootstrap-3.3.5/fileinput_locale_zh.js"gt;lt;/scriptgt;nbsp; 其中fileinput.js和fileinput_locale_zh.js都在插件待官方包中,angular.min.js和bootstrap.min.js就不多介绍了 二、多文件上传 首先在页面中定义file控件: lt;input id="input-images" type="file" multiple class="file-loading" accept="image/*"gt; 然后对该控件进行初始化,就可以实现该组件的多文件上传了:
$("#input-images").fileinput({
uploadUrl: "lt;%=path%gt;" + "/album/pictureFileUpload",
allowedFileExtensions: ["jpg", "png", "gif"],
resizePreference: 'height',
maxFileCount: 10,
language: 'zh',
overwriteInitial: false,
resizeImage: true,
});
当然,初始化时的属性有很多,这里不一一介绍了,后台代码(使用JFinal)如下:
public void pictureFileUpload() {
UploadFile uploadFile = getFile();
renderJson("{"link":" + ""/fileinput/upload/" + uploadFile.getFileName()
+ """ + ","fileName":"" + uploadFile.getOriginalFileName()
+ ""}");
}
注意最后一定要返回Json,哪怕返回一个空json串(“{}”),返回的值保存在前台的data.response中。 三、已有文件的加载与删除 已有文件的加载是指将服务器上已经存在的文件展示在该控件中,以实现文件管理,提供删除功能,这主要依赖于initialPreview实现的。 将服务器上的文件名称和文件地址获取之后,使用initialPreview和initialPreviewConfig完成加载和定义删除操作:
var initPreview = new Array();//展示元素
var initPreviewConfig = new Array();//展示设置
$.post(
"lt;%=path%gt;" + "/album/getPicsByAlbum",
{albumId : albumId},
function(result) {
for(var i=0;ilt;result.length;i++){
var pictureFile = result[i];
//用于展示已经上传的图片
initPreview.push("lt;img src='" + pictureFile.PICADDRESS
+ "' class='file-preview-image' alt='"+pictureFile.PICNAME+"' title='"+pictureFile.PICNAME+"'gt;");
var config = new Object();
config.caption = pictureFile.PICNAME;
config.url="lt;%=path%gt;" + "/album/deletePicById";
config.key=pictureFile.ID;
initPreviewConfig.push(config);
}
initFileInput($scope);
$("#input-images").fileinput('refresh', {
initialPreview: initPreview,
initialPreviewConfig: initPreviewConfig
});
}
);
点击删除图标,会默认把config中待key值传至后台,后台中定义deletePicById方法即可:
public void deletePicById() {
String picId = getPara("key");
service.deletePicById(Integer.valueOf(picId));
renderJson("{}");
}
四、几点疑问的解答 1、为什么model里没有属性,却可以在前端展示相关属性? 2、(参考代码)中初始化FileInput为什么要执行clear,destory操作? 因为FileInput插件在选择文件后,不管有没有上传,都会保留文件在file域中,因此再点击时会显示上一次选择的文件,不符合多相册管理的需求,原本以为clear操作就可以清空file域(官方文档这么说的),但实际操作发现并没有清空,因此才调用clear,destory后再重新初始化文件上传控件。(这一点不太确定,希望有大神可以指点) 3、保存时怎么知道那些图片需要存数据库,这是基于什么实现的? (编辑:佛山站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |



