swf 上传
推荐这个博客:http://blog.csdn.net/hi_kevin/article/details/23430345
这个文章很不错,我推荐这个文章:http://leeon.me/upload/other/swfupload.html#globals
var swfu;
window.onload = function () {
var settings = {
flash_url: "/plugins/swfupload/core/Flash/swfupload.swf",
upload_url: "/system/upload/annex",
post_params: {"PHPSESSID": sessionId, "name": "annex"},
file_size_limit: "30 MB",
file_types: "*.gif;*.jpg;*.jepg;*.png;*.bmp;*.txt;*.zip;*.rar;*.pdf;*.ppt;*.doc;*.xls;*.xlsx;*.docx;*.rtf",
file_types_description: "jap,png,rar,zip",
file_upload_limit: 0,
file_queue_limit: 0,
custom_settings: {
progressTarget: "fsUploadProgress",
cancelButtonId: "btnCancel"
},
debug: false, // Button settings
button_width: "80",
button_height: "20",
button_placeholder_id: "spanButtonPlaceHolder",
button_text: '上传附件',
button_text_left_padding: 12,
button_text_top_padding: 3, // The event handler functions are defined in handlers.js
file_queue_error_handler: fileQueueError,
file_dialog_complete_handler: replyFileDialogComplete,//当选择文件对话框关闭,并且所有选择文件已经处理完成(加入上传队列成功或者失败)时,此事件被触发
upload_error_handler: uploadError,
upload_success_handler: replyUploadSuccess,//当文件上传的处理已经完成
upload_start_handler: uploadStart,
file_queued_handler: fileQueued,// 文件被加入队列时触发 upload_progress_handler: uploadProgress //进度
// upload_start_handler: upload_start_handlers //在文件往服务端上传之前触发此事件,可以在这里完成上传前的最后验证以及其他你需要的操作
// upload_progress_handler : uploadProgress,
};
swfu = new SWFUpload(settings);
}; function fileQueued(file) {
var swfUpload = this;
var listItem = '<li id="' + file.id + '">';
listItem += '文件:<em>' + file.name + '</em>(' + Math.round(file.size/1024) + ' KB)';
listItem += '<span class="progressValue"></span>'
+ '<div class="progressBar"><div class="progress"></div></div>'
+ '<p class="status" >Pending</p>'
+ '<span class="cancel" > </span>'
+ '</li>';
$("#logList").append(listItem);
// $("li#" + file.id + " .cancel").click(function(e) {
// swfUpload.cancelUpload(file.id);
// $("li#" + file.id).slideUp('fast');
// })
// swfUpload.startUpload();
} function uploadStart(file) {
if (file) {
$("#logList li#" + file.id).find('p.status').text('上传中...');
$("#logList li#" + file.id).find('p.progressValue').text('0%');
}
}
/**
* 文件上传过程中定时触发,更新进度显示
* @param file 上传的文件
* @param bytesCompleted 已上传大小
* @param bytesTotal 文件总大小
*/
function uploadProgress(file,bytesCompleted,bytesTotal) {
var percentage = Math.round((bytesCompleted / bytesTotal) * 100);
$("#logList li#" + file.id).find('div.progress').css('width',percentage + '%');
$("#logList li#" + file.id).find('span.progressValue').text(percentage + '%');
} //上传成功动作
function replyUploadSuccess(file, serverData) {
try { var data = JSON.parse(serverData);
var size = $("div .btn-group").attr("data-size");
layer.msg("附件(" + file.name + ")上传成功", 1, {type: 1}, function () {
//显示附件信息
var html = '<div class="btn-group" data-size="0" style="margin-left: 70px;" id="' + data.fileId + '"><input type="checkbox" class="annex"' +
' style="float:left;" checked name="annex[' + data.fileId + ']" value="' + file.name + '" ><div name="filename" style="float:left;" >' + file.name + '</div>' +
'<a style="margin-left:20px;cursor:pointer;float:left; " onclick="delAnnex(this)" >删除</a></div> '; var item = $("#logList li#" + file.id);
item.find('div.progress').css('width','100%');
item.find('span.progressValue').css('color','red').text('100%');
item.addClass('success').find('p.status').html('上传完成!'); if(size==null ||size=='undefied'){
$("#showAnnex").append(html);
$("div .btn-group").attr("data-size", file.size);
}else{
var total_size = size * 1 + file.size * 1;
$("div .btn-group").attr("data-size", total_size);
var max_size = $("div .btn-group").attr("data-size");
if(max_size>=52428800){
alert("附件总大小不超过 50M"); return ;
}else{
$("#showAnnex").append(html);
}
}
//绑定文件删除事件
$(".annex").change(function () {
if (!$(this).is(':checked')) {
$(this).parent().remove();
}
//TODO 检查是否显示上传框
});
});
} catch (ex) {
this.debug(ex);
alert(ex);
}
} //上传文件
function replyFileDialogComplete(numFilesSelected, numFilesQueued) {
try {
this.startUpload();
} catch (ex) {
this.debug(ex);
}
} //删除附件操作
function delAnnex(obj) {
var annex = obj.parentNode.firstChild.value;
$.ajax({
type: "get",
url: "/email/draft/del-annex?annex=" + annex,
dataType: "json",
success: function (data) {
if (data.status == 'y') {
obj.parentNode.remove();
layer.msg(data.info, 1, 9);
$_this.parent().parent().remove();
} else {
layer.alert(data.info);
}
}
});
}
swf 上传的更多相关文章
- swf上传文件
以下是自学it网--中级班上课笔记 网址:www.zixue.it 引入的js包自己在网上找一个,这里好像不支持上传文件,反正我没找到,呵呵~~ html文件 <!DOCTYPE html PU ...
- swf上传
swfupload多文件异步上传 多文件选择异步上传的原理 传统上:多个文件逐一选.PHP开始处理,循环上 PHP+Flash上:JS调用flash控,Flash批量选取并保持选取所有文件列 swfu ...
- jquery.uploadify文件上传组件
1.jquery.uploadify简介 在ASP.NET中上传的控件有很多,比如.NET自带的FileUpload,以及SWFUpload,Uploadify等等,尤其后面两个控件的用户体验比较好, ...
- jquery文件上传控件 Uploadify 问题记录
Uploadify v3.2.1 首先引用下面的文件 <!--上传控件 uploadify--> <script type="text/javascript" s ...
- PHP上传大文件 分割文件上传
最近遇到这么个情况,需要将一些大的文件上传到服务器,我现在拥有的权限是只能在一个网页版的文件管理系统来进行操作,可以解压,可以压缩,当然也可以用它来在线编辑.php文件. 文件有40M左右,但是服务器 ...
- JQuery文件上传插件uploadify在MVC中Session丢失的解决方案
<script type="text/javascript"> var auth = "@(Request.Cookies[FormsAuthenticati ...
- jsp+servlet+jquery 用jquery uploadify最新版本实现多文件上传
//这是script代码 <link rel="stylesheet" type="text/css" href="uploadify/uplo ...
- ASP.NET Jquery+ajax上传文件(带进度条)
效果图 支持ie6+,chrome,ie6中文文件名会显示乱码. 上传时候会显示进度条. 需要jquery.uploadify.js插件,稍后会给出下载 前台代码 <%@ Page Langua ...
- Springmvc+uploadify实现文件带进度条批量上传
网上看了很多关于文件上传的帖子,众口不一,感觉有点乱,最近正好公司的项目里用到JQuery的uploadify控件做文件上传,所以整理下头绪,搞篇文档出来,供亲们分享. Uploadify控件的主要优 ...
随机推荐
- P2475 [SCOI2008]斜堆(递归模拟)
思路 可并堆真是一种神奇的东西 不得不说这道题是道好题,虽然并不需要可并堆,但是能加深对可并堆的理解 首先考虑斜堆的性质,斜堆和左偏树相似,有如下的性质 一个节点如果有右子树,就一定有左子树 最后插入 ...
- kubernetes 实战6_命令_Share Process Namespace between Containers in a Pod&Translate a Docker Compose File to Kubernetes Resources
Share Process Namespace between Containers in a Pod how to configure process namespace sharing for a ...
- redis中 Could not get a resource from the pool 异常解决
https://blog.csdn.net/qh_java/article/details/54669973
- node.js 学习笔记一
2017-05-01 安装node 我没安装,下载即使用.要全局使用的话把node加入到环境变量中即可. 以下命令环境均为 cmd . 体验 体验一: 在命令行输入 node ,即进入 node 程序 ...
- python写web服务器
#coding = utf-8 from http.server import BaseHTTPRequestHandler, HTTPServer class RequestHandler(Base ...
- C# 委托例子
两个子窗口向一个主窗口发送信息 主窗口: using System; using System.Collections.Generic; using System.ComponentModel; us ...
- snakemake使用笔记
snakemake是一个用来编写任务流程的工具,用python编写的,因此其执行的流程脚本也比较通俗易懂,易于理解. 一.从一个简单的例子开始 1.安装snakemake 安装snakemake的方法 ...
- 【BZOJ】3572: [Hnoi2014]世界树
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3572 算是细节题了吧.. 构出虚树,考虑z正反DP两次求出虚树中每个点最近的议事处是哪一个 ...
- TextView显示内容不全
今天开发遇到一个问题,发现TextView显示不全,很纳闷,看图: 正常情况应该是这个样子的: 造成这种情况的原因是: TextView被快速并且多次的设置内容值造成的. 我的场景: 我点击全选按钮, ...
- 《剑指offer》第六十一题(扑克牌的顺子)
// 面试题61:扑克牌的顺子 // 题目:从扑克牌中随机抽5张牌,判断是不是一个顺子,即这5张牌是不是连续的. // 2-10为数字本身,A为1,J为11,Q为12,K为13,而大.小王可以看成任意 ...