官方站点:
http://www.swfupload.org/
DEMO地址:
http://demo.swfupload.org/
上一篇介绍的简历的例子,在struts2框架下基本完成了使用SWFUpload上传文件的功能。但是在我们自己的项目中不仅仅只是完成上传的功能,还要和我们的项目更进一步的整合在一起。
SWFUpload的上传过程中各个步骤的显示方式要改变;我们需要往服务器传递参数;需要从服务器返回参数;这些问题上面的例子都没有解决。
看下面这个图片,这是我在项目中的SWFUpload上传附件的效果(其实仿的是126邮箱做的)。
上传过程中
红x:取消上传
上传完成。(上传成功的附件不消失,上传发生错误文件消失。)
删除:删除上传完成的文件(删除后文件逐渐消失)。
下面我介绍一下我是怎么做的。请先了解
详细介绍SWFUpload和
struts2+swfUpload简单例子这2篇的关于SWFUpload的知识。
(一)、SWFUpload如何改名upload控件的样式。
1、修改上传flash按钮样式
SWFUpload Demo文件中提供了一个XPButtonUploadText_61x22.png 图片文件
重新制作一个类似的图片文件替换它。
如果你做的这个图片文件的长款与原图不同,不要忘记修改
// 按钮的处理
button_image_url : "images/XPButtonUploadText_61x22.png",
button_placeholder_id : "spanButtonPlaceholder1",
button_width: 61,
button_height: 22,
2、修改上传队列附件样式
如果你不是很了解css和js的话自定义这个样式其实还是挺复杂的。
这个东西的构建是通过fileprogress.js文件和defaut.css来完成的。
function FileProgress(file, targetID) {
this.fileProgressID = file.id;
this.opacity = 100;
this.height = 0;
this.fileProgressWrapper = document.getElementById(this.fileProgressID);
if (!this.fileProgressWrapper) {
this.fileProgressWrapper = document.createElement("div");
this.fileProgressWrapper.className = "progressWrapper";
this.fileProgressWrapper.id = this.fileProgressID;
this.fileProgressElement = document.createElement("div");
this.fileProgressElement.className = "progressContainer";
var progressCancel = document.createElement("a");
progressCancel.className = "progressCancel";
progressCancel.href = "#";
progressCancel.style.visibility = "hidden";
progressCancel.appendChild(document.createTextNode(" "));
var progressText = document.createElement("div");
progressText.className = "progressName";
progressText.appendChild(document.createTextNode(file.name));
var progressBar = document.createElement("div");
progressBar.className = "progressBarInProgress";
var progressStatus = document.createElement("div");
progressStatus.className = "progressBarStatus";
progressStatus.innerHTML = " ";
this.fileProgressElement.appendChild(progressCancel);
this.fileProgressElement.appendChild(progressText);
this.fileProgressElement.appendChild(progressStatus);
this.fileProgressElement.appendChild(progressBar);
this.fileProgressWrapper.appendChild(this.fileProgressElement);
document.getElementById(targetID).appendChild(this.fileProgressWrapper);
} else {
this.fileProgressElement = this.fileProgressWrapper.firstChild;
this.reset();
}
this.height = this.fileProgressWrapper.offsetHeight;
this.setTimer(null);
}
//……
}
每当我们选择一个文件上传时它就会new FileProgress(file, this.customSettings.progressTarget);
根据上面的代码分析其实就是在网页中添加了以下html代码
<div id=file.id class="progressWrapper">
<div class="progressContainer" >
<a href="#" class="progressCancel" style="visibility:hidden"> </a>
<div class="progressName"> file.name </div>
<div class="progressBarInProgress"></div>
<div class="progressBarStatus"> </div>
</div>
</div>
//css文件在defaut.css中。
//file.id 和file.name 选中上传文件的id和name属性的值。
这段代码会被插入下面这段代码里面
<div class="fieldset flash" id="fsUploadProgress1">
<span class="legend">文件上传</span>
</div>
如果你的css和javascrpt能力很强,动态在页面中创建对象改变这个控件的外貌是不是很容易呢。
选择好事件重写事件代码就ok了。(相关知识见
详细介绍SWFUpload)
不过提醒一下,不要改变现有的这些对象的顺序,您看下后面的代码就这道了。
比如:
this.fileProgressElement.childNodes[3].className = "progressBarInProgress";
this.fileProgressElement.childNodes[3].style.width = percentage + "%";
3、如何控制上传队列中的文件消失(hidden)情况
// Fades out and clips away the FileProgress box.
FileProgress.prototype.disappear = function () {//…}
这段代码是FileProgress文件disappear的属性代码。
如果想上传后FileProgress不消失
在fileprogress.js文件找到下面代码,像我一样注释掉最后3行就ok了。当然你也可以在相应的事件中重写函数。
FileProgress.prototype.setComplete = function () {
this.fileProgressElement.className = "progressContainer blue";
this.fileProgressElement.childNodes[3].className = "progressBarComplete";
this.fileProgressElement.childNodes[3].style.width = "";
var oSelf = this;
//this.setTimer(setTimeout(function () {
// oSelf.disappear();
//}, 10000));
};
删除的时候让FileProgress消失
在fileprogress.js文件中增加
FileProgress.prototype.setDelete = function () {
this.fileProgressElement.className = "progressContainer";
this.fileProgressElement.childNodes[3].className = "progressBarError";
this.fileProgressElement.childNodes[3].style.width = "";
var oSelf = this;
this.setTimer(setTimeout(function () {
oSelf.disappear();
}, 0));
};
在删除事件中调用即可。
(二)SWFUpload像服务器传递参数
http://hanxin0311.iteye.com/blog/1913946
(三)SWFUpload接受服务器Action返回的参数
http://hanxin0311.iteye.com/blog/1915644
(四)SWFUpload中文乱码问题
http://hanxin0311.iteye.com/blog/1915648
附件提供项目下载:(通过myeclipse AddStruts功能增加的struts2.1,如果项目导入myeclipse后,报错,下载
上一篇文章的例子用里面lib包就可以)
项目开发工具myeclipse8.5
下载代码 (如果附件不能下载点击此处下载)
data:image/s3,"s3://crabby-images/0988f/0988f791d4fab67843e71d15d1a067f34baaaf78" alt="点击查看原始大小图片"
- 大小: 22.5 KB
data:image/s3,"s3://crabby-images/1529f/1529f0705102398287b397bd8ba09d75b08a8595" alt="点击查看原始大小图片"
- 大小: 25.5 KB
data:image/s3,"s3://crabby-images/7b829/7b829f46956b9082e94ed7ad186c536ae2569665" alt="点击查看原始大小图片"
- 大小: 2.9 KB
data:image/s3,"s3://crabby-images/cbe8d/cbe8d6763a12417b4541499d711583b562c38056" alt="点击查看原始大小图片"
- 大小: 3.9 KB
data:image/s3,"s3://crabby-images/69078/690789f44d67f2d41a22547acf0e77e2047865c4" alt="点击查看原始大小图片"
- 大小: 3.1 KB
分享到:
相关推荐
这个"三、struts2+swfUpload简单例子"很可能是关于如何集成这两个技术来创建一个高效的文件上传功能的教程。 在集成Struts2和SwfUpload的过程中,有几个关键知识点是必不可少的: 1. **Struts2框架**:Struts2提供...
SWFUpload上传组件的一个完整的例子,后台由Struts2完成,有上传进度显示,可以多文件上传,如果你想使用SWFUpload组件但还不知道怎样使用,可以下载下来运行一下试试,看一下源码就知道了。
本教程将详细讲解如何利用SWFUpload与Struts2框架来实现多文件上传的示例。 首先,让我们了解SWFUpload。SWFUpload是一款开源的Flash上传组件,它允许用户在不离开当前页面的情况下上传多个文件。通过在浏览器上...
SWFUpload上传组件的一个完整的例子,后台由Struts2完成,有上传进度显示,可以多文件上传,如果你想使用SWFUpload组件但还不知道怎样使用,可以下载下来运行一下试试,看一下源码就知道了。
在服务器端,SWFUpload支持多种编程语言,本例中使用的是Java(Struts 1.x)。 #### 目录结构解析 SWFUpload的核心文件夹包含了所有必需的资源和脚本,包括但不限于: - **SWFUpload**:核心文件夹,包含SWFUpload...
利用swfupload结合struts2实现的一个上传mp3和mp4文件,并可以在页面上用html5进行播放,本例只是自己动手写的一个小例子。注意:为了节省资源,例子中并未包含struts2的jar,需要手动添加struts2用到的jar包
这通常涉及到MVC框架(如Spring MVC或Struts2)中的Controller层。 - 文件接收后,可能需要进行验证(如大小、类型等),存储到服务器的指定位置,或者保存到数据库的二进制字段。 - 为了与前端通信,Java后端可能...