使用webUploader上传图片(用js触发选择图片)

webuploader的优点是几乎支持所有的平台,pc端支持ie6+,支持IOS和Android,它可以自动压缩图片(仅支持jpeg,在某些参数设置下用肉眼不能看出压缩之后的差别,最多可缩小60倍),生成base64地址编码,能根据平台自动切换flash或H5上传。

通常情况下,需要给一个特定div绑定一个onclick事件,当然这些都是webUploader内部完成的。先看主要代码:

var server = r.host;
        var swf = 'http://cdn.staticfile.org/webuploader/0.1.0/Uploader.swf';
        var object = '';
        var base64Src = '';

        var uploader = WebUploader.create({
            auto: true,
            swf: swf,
            server: server,
            pick: domId,
            duplicate:true,
            compress:{
                width: 800,
                height: 800,
                quality: 90,
                allowMagnify: false,
                crop: false,
                preserveHeaders: true,
                noCompressIfLarger: false,
                compressSize: 50
            },
            thumb:{
                width: 800,
                height: 800,
                quality: 70,
                allowMagnify: true,
                crop:false,
                type: 'image/jpeg'
            },
            accept: {
                title: 'Images',
                extensions: 'gif,jpg,jpeg,bmp,png',
                mimeTypes: 'image/jpg,image/jpeg,image/png'
            }
        });

        uploader.on( 'fileQueued', function( file ) {
            var loading = layer.load(2);

            uploader.makeThumb( file, function( error, src ) {
                if ( error ) {
                    alert('不能预览');
                    layer.close(loading);
                }else{
                    base64Src = src;
                    previewCallback(src);
                    layer.close(loading);
                }
            });
        });

        uploader.on('uploadBeforeSend', function (obj, data, headers) {
            delete r.host;

            data = $.extend(data,r);
            data.key = object = data.key + '/' + uuid(16) + '.jpg';

            headers['Access-Control-Allow-Origin'] = "*";
        });

        uploader.on( 'uploadSuccess', function( file,response ) {
            $.post(bao.dealWithObject,{object:object},function(r){
                if(r.code == 1){
                    setCallback(r.data);//image_id
                    mergeCallback(base64Src, r.data);
                }
            });
        });

        uploader.on( 'uploadError', function( file ) {
            alert('上传图片失败,请重试');
        });

看以看到,webUploader把选择、预览、上传几个步骤分开了,要分别写到不同的函数里。这里有一个技巧,就是预览和上传分开,这样用户看到图片的速度会很更快,而图片在另一个函数里异步上传,用户是没有感知的。

webUploader如果能结合OSS或者7牛,可以直接把图片上传到图片服务器,将不会占用应用服务器的贷款和性能。

这需要一个验签过程,具体办法是每次上传的时候去应用服务器取得签名,然后作为参数和图片一起上传到图片服务器。关键代码:

$.post(signatureUrl,{},function(r){
    if(r.code === 0){
        alert(r.msg);
    }else{
        var signature = {
            'key' : r.dir,
            'policy': r.policy,
            'OSSAccessKeyId': r.accessid,
            'success_action_status' : '200',
            'signature': r.signature,
            'host': r.host
        };
        callback(signature);
    }
});

可能不同的服务商代码不太一样,原理是相似的。这里也有一些技巧,比如把缓存时间设置成一个可接受的值,在一段时间内不用重复取值。

最后,有时候我们不想把选择图片的动作绑定到一个div上,或者我们上传的代码已经写好,只需要重构就可以了,这个时候我们需要用js触发上传图片的动作。

尝试过调用picker下的div,没有作用,也去github上提过issues,但是没有回应。无意中发现可以这样解决:

<button onclick='trigger()'>trigger</button>
<button id="picker" style="display:hone">picker</button>
<script>
var uploader = WebUploader.create({
    auto: true,
    swf: swf,
    server: server,
    pick: '#picker'
});
function trigger(){
    $('#picker').find('input').click();
}
</script>

这样就可以触发选择图片的动作了,也就是说,可以用js触发,但是,总得有鼠标点一下。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 小宇说:最爱王石。 非常高兴,也非常,感觉非常特别。即将过去的2016年,和大家在这里共祝,从大家的呼声当中呢,感...
    燕飞宇阅读 935评论 0 1
  • 阿金与妻商量决定:明天(2015年3月22日)接老家岭下亲房的老弟和弟媳们到县城来欢聚欢聚,喝喝酒水,以表亲房众弟...
    镇南方良金阅读 104评论 0 1