经常做系统的时候会遇到上传组件,特别是大文件的时候总是很郁闷,长时间无响应导致糟糕的用户体验,所以决定采用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的更多相关文章

  1. 【翻译】Ext JS 5的平板支持

    原文:Ext JS 5 Tablet Support Ext JS已被公认为桌面Web应用程序的领先框架.自从平板开始在全球挑战PC的销售,无论是个人还是企业,电脑横向的应用已经产生急剧的变化.Sen ...

  2. [转载]ExtJs4 笔记(3) Ext.Ajax 对ajax的支持

    作者:李盼(Lipan)出处:[Lipan] (http://www.cnblogs.com/lipan/)     本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封装,函数事 ...

  3. ExtJs4 笔记(3) Ext.Ajax 对ajax的支持

    本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封装,函数事件操作封装,还有扩展的常用函数等.Ajax服务端交互式操作是提交到.NET MVC.后续服务端交互都采用这一方式实现. ...

  4. 12. Ext.Ajax 对ajax的支持

    转自:http://www.cnblogs.com/lipan/archive/2011/12/09/2272793.html 本篇主要介绍一下ExtJs常用的几个对JS语法的扩展支持,包括Ajax封 ...

  5. Ext JS - 问答

    Ext JS - 问答 在下面你将可以找到关于Ext JS 的最常见问题的答复.如果没有找到您所需的答复,请访问 Ext JS 论坛或者提交一个支持申请. 如果你确信你的问题可以对本页有补充,请让我们 ...

  6. SWFUpload简介及中文参考手册(share)

    SWFUpload SWFUpload 版本 2 概览 (Overview) 入门( Getting Started) js对象 (SWFUpload JavaScript Object) 构造器(C ...

  7. [转]使用Sencha Ext JS 6打造通用应用程序

    原文地址:http://www.uedsc.com/using-sencha-ext-js-6-to-build-universal-apps.html 在Sencha和整个Ext JS团队的支持下, ...

  8. SWFUpload 2.5.0版 官方说明文档 中文翻译版

    原文地址:http://www.cnblogs.com/youring2/archive/2012/07/13/2590010.html#setFileUploadLimit SWFUpload v2 ...

  9. 【Ext.Net学习笔记】06:Ext.Net GridPanel的用法(GridPanel 折叠/展开行、GridPanel Selection、 可编辑的GridPanel)

    GridPanel 折叠/展开行 Ext.Net GridPanel的行支持折叠/展开功能,这个功能个人觉得还说很有用处的,尤其是数据中包含图片等内容的时候. 下面来看看效果: 使用行折叠/展开功能之 ...

随机推荐

  1. javax.persistence.PersistenceException: No Persistence provider for EntityManager named ...

    控制台下输出信息 原因:persistence.xml必须放在src下META-INF里面. 若误放在其他路径,就会迷路.

  2. .NET通过RFC读取SAP数据

    本篇文章中我主要讲的是.NET如何通过RFC从SAP中读取数据.为了功能的可复用性,我将调用RFC的代码从业务层中分离出来单独建立在一个namespace中. 当然除了需要我们自己编写代码以外,还需要 ...

  3. paip.解决 数据库mysql增加列 字段很慢添加字段很慢

    paip.解决 数据库mysql增加列 字段很慢添加字段很慢 #环境如下: mysql5.6    数据仅仅3w alter table xxx add column yyy int default ...

  4. paip.输入法编程---词库多意义条目分割 python实现.

    paip.输入法编程---词库多意义条目分割 python实现. ==========子标题 python mysql 数据库操作 多字符分隔,字符串分割 字符列表循环  作者 老哇的爪子 Attil ...

  5. 如何将Scrapy 部署到Scrapyd上?

    安装上传工具 1.上传工具 scrapyd-client 2.安装方法: pip install scrapyd-client 3.上传方法: python d:\Python27\Scripts\s ...

  6. php 3种常见设计模式

    1.工厂模式 <?php namespace Facebab; class Factory { static function createDatabase () { return new Da ...

  7. Advacned Puppet: Puppet Master性能调优

    本文是Advanced Puppet系列的第一篇:Puppet master性能调优,谈一谈如何优化和提高C/S架构下master端的性能. 故事情节往往惊人地类似:你是一名使用Puppet管理线上业 ...

  8. Java蛇形数组的简单实现代码

    上周五和朋友聊天谈到个蛇形数组的java实现办法,命题是:假设一个二维数组宽w高h,从1开始蛇形输出. int[][] numberMatric = new int[w][h]; 当时午睡过头脑袋不清 ...

  9. 奇怪吸引子---TreeScrollUnifiedChaoticSystem

    奇怪吸引子是混沌学的重要组成理论,用于演化过程的终极状态,具有如下特征:终极性.稳定性.吸引性.吸引子是一个数学概念,描写运动的收敛类型.它是指这样的一个集合,当时间趋于无穷大时,在任何一个有界集上出 ...

  10. oracle导入导出小记

    问题:11.2.0.3.0 导入  11.2.0.2.0 都是oracle 11g ,从0.3.0到0.2.0 报错,以为是版本问题,结果不是 采用impdp 导入exp导出的文件会报错 所以改为im ...