ext 3.x 让uploadPanel支持swfupload
经常做系统的时候会遇到上传组件,特别是大文件的时候总是很郁闷,长时间无响应导致糟糕的用户体验,所以决定采用swfupload来支持文件上传。
大体代码如下。
var upload = {}; upload.UploadPanel = function (cfg) { this.iconCls = 'add'; this.text = 'upload'; Ext.apply(this, cfg); this.setting = { upload_url: this.uploadUrl, flash_url: this.flashUrl || '../../../../Scripts/Platform/Upload/swfupload.swf', file_size_limit: this.fileSize || (1024 * 50), file_post_name: this.filePostName, file_types: this.fileTypes || "*.*", file_types_description: "All Files", file_upload_limit: "5", //file_queue_limit : "10", post_params: this.postParams || { savePath: 'upload\\' }, use_query_string: true, debug: false, button_cursor: SWFUpload.CURSOR.HAND, button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT, button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT, button_action: SWFUpload.BUTTON_ACTION.SELECT_FILE, custom_settings: { scope_handler: this }, file_queued_handler: this.filequeuedhandler, file_queue_error_handler: this.filequeueerrorhandler, file_dialog_complete_handler: this.filedialogcomplete_handler, upload_start_handler: this.uploadstarthandler, upload_progress_handler: this.onUploadProgress, upload_error_handler: this.uploaderrorhandler, upload_success_handler: this.onUploadSuccess, upload_complete_handler: this.uploadcompletehandler, queue_complete_handler: this.queuecompletehandler }; upload.UploadPanel.superclass.constructor.call(this, { listeners: { 'afterrender': function (e) { var em = e.btnEl.parent('em'); var placeHolderId = Ext.id(); em.setStyle({ position: 'relative', display: 'block' }); em.createChild({ tag: 'div', id: placeHolderId }); this.swfupload = new SWFUpload(Ext.apply(this.setting, { button_width: em.getWidth(), button_height: em.getHeight(), button_placeholder_id: placeHolderId })); this.swfupload.uploadStopped = false; Ext.get(this.swfupload.movieName).setStyle({ position: 'absolute', top: 0, left: -2 }); }, scope: this, delay: 100 } }); } Ext.extend(upload.UploadPanel, Ext.Button, { filequeuedhandler: function () { this.startUpload(); }, filequeueerrorhandler: function () { }, filedialogcomplete_handler: function () { }, uploadstarthandler: function () { }, onUploadProgress: function (file, bytesComplete, totalBytes) { }, uploaderrorhandler: function () { }, onUploadSuccess: function () { }, uploadcompletehandler: function () { }, queuecompletehandler: function () { } }); Ext.reg('btnupload', upload.UploadPanel);
于是调用的时候就很easy了。
new Ext.Window({ width: 650, title: 'UPLOAD', height: 300, tbar: [ { xtype: 'btnupload', text: '上传', fileSize: 1024 * 50, uploadUrl: 'SaveFile', filePostName: 'file', fileTypes: '*.jpg;*.gif;*.png;*.jpeg', postParams: { savePath: 'upload\\' }, onUploadSuccess: function (s, f) { console.log(f); }, onUploadProgress: function (file, bytesComplete, totalBytes) { var percent = Math.ceil((bytesComplete / totalBytes) * 100); percent = percent == 100 ? 100 : percent; console.log(percent); } }], items: [ ] }).show();
这样需要上传的时候就很轻松了。
ext 3.x 让uploadPanel支持swfupload的更多相关文章
- 【翻译】Ext JS 5的平板支持
原文:Ext JS 5 Tablet Support Ext JS已被公认为桌面Web应用程序的领先框架.自从平板开始在全球挑战PC的销售,无论是个人还是企业,电脑横向的应用已经产生急剧的变化.Sen ...
- [转载]ExtJs4 笔记(3) Ext.Ajax 对ajax的支持
作者:李盼(Lipan)出处:[Lipan] (http://www.cnblogs.com/lipan/) 本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封装,函数事 ...
- ExtJs4 笔记(3) Ext.Ajax 对ajax的支持
本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封装,函数事件操作封装,还有扩展的常用函数等.Ajax服务端交互式操作是提交到.NET MVC.后续服务端交互都采用这一方式实现. ...
- 12. Ext.Ajax 对ajax的支持
转自:http://www.cnblogs.com/lipan/archive/2011/12/09/2272793.html 本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封 ...
- Ext JS - 问答
Ext JS - 问答 在下面你将可以找到关于Ext JS 的最常见问题的答复.如果没有找到您所需的答复,请访问 Ext JS 论坛或者提交一个支持申请. 如果你确信你的问题可以对本页有补充,请让我们 ...
- SWFUpload简介及中文参考手册(share)
SWFUpload SWFUpload 版本 2 概览 (Overview) 入门( Getting Started) js对象 (SWFUpload JavaScript Object) 构造器(C ...
- [转]使用Sencha Ext JS 6打造通用应用程序
原文地址:http://www.uedsc.com/using-sencha-ext-js-6-to-build-universal-apps.html 在Sencha和整个Ext JS团队的支持下, ...
- SWFUpload 2.5.0版 官方说明文档 中文翻译版
原文地址:http://www.cnblogs.com/youring2/archive/2012/07/13/2590010.html#setFileUploadLimit SWFUpload v2 ...
- 【Ext.Net学习笔记】06:Ext.Net GridPanel的用法(GridPanel 折叠/展开行、GridPanel Selection、 可编辑的GridPanel)
GridPanel 折叠/展开行 Ext.Net GridPanel的行支持折叠/展开功能,这个功能个人觉得还说很有用处的,尤其是数据中包含图片等内容的时候. 下面来看看效果: 使用行折叠/展开功能之 ...
随机推荐
- ubuntu14.04中文楷体变默认字体
使用ubuntu以来,最让人头疼的事情就是在英文系统里面使用中文,一般中文字体都很难看,要么有锯齿,要么就是楷体.经过网上搜索找到一堆方法.一个个尝试之后觉得以下方式是最简单有效的. 1.安装font ...
- 整合GreyBox放大显示图片
<s:iterator value="#request.photoList" id="photo" status="stu"> ...
- 通过MSSQL连接服务器连接至Oracle数据库
前言 有很多时候,我们需要MSSQL与Oracle进行跨库查询或数据交互.本篇随笔将阐述如何通过MSSQL的连接服务器连接至Oracle数据库,并且读取数据的示例. 具体步骤 首先需要到Oracle的 ...
- 题目一:一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
题目一:一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)? //一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米 doub ...
- 移动页面HTML5自适应手机屏幕宽度
标签: 网上关于这方面的文章有很多,重复的东西本文不再赘述,仅提供思路,并解释一些其他文章讲述模糊的地方. 1.使用meta标签,这也是普遍使用的方法,理论上讲使用这个标签是可以适应所有尺寸的屏幕的, ...
- 用inno Setup做应用程序安装包的示例脚本(.iss文件)(
用innoSetup做应用程序安装包的示例脚本(.iss文件),具体要看innoSetup附带的文档,好象是pascal语言写的脚本. 示例1(应用程序.exe,客户端安装): ;{089D6802- ...
- android: SQLite使用 SQL 操作数据库
虽然 Android 已经给我们提供了很多非常方便的 API 用于操作数据库,不过总会有一些 人不习惯去使用这些辅助性的方法,而是更加青睐于直接使用 SQL 来操作数据库.这种人 一般都是属于 SQL ...
- [转] 配置Log4j
Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出Log4J的运行环境 ...
- 使用visualVM 1.3.8(visualvm_138-ml.zip) 监控远程Tomcat运行情况
服务端CentOS6.4 x64安装的是jdk1.7 下载visualVM1.3.8-ml 也就是多语言版本,包含中文,界面用起来方便.官方下载地址比较慢,百度上搜索的都是csdn,51cto等必须登 ...
- 对于程序开发者看书(指实在的书而不是PDF)的好处。(个人看法而已)
书是实在的东西.不同PDF.他能带你进入一种学习态度的环境 书上已经所列了知识点.看了.那些知识点就是你的. 第一次看,未必完全理解到里面的东西.说不定过几天,几周,几个月,甚至几年.再看.就有可能看 ...