step1:引入文件

  • 引入Plupload *
    该SDK上传功能集于Plupload插件封装,所以需要下载Plupload; plupload.dev.js

  • 引入qiniu.js
    为了简便,当时直接从官网示例中复制的js文件

  • 引入moxie.js
    因为Plupload插件除了能解决h5的上传问题,还能上传flash等,所以需要该文件。本来我们是不需要的,但由于plupload.dev.js和qiniu.js里面有依赖于moxie.js的代码,如果不引入,就一直报错:moxie not defined,挺头疼的,索性一并引入了

因为互相依赖,所以引入的顺序也很重要,先是moxie.js => plupload.dev.js => qiniu.js => index.js

step2:查看七牛云api,相关参数配置(七牛云开发者中心)

var uploader = Qiniu.uploader({runtimes: 'html5,flash,html4',      // 上传模式,依次退化browse_button: 'pickfiles',         // 上传选择的点选按钮ID,必需// 在初始化时,uptoken,uptoken_url,uptoken_func三个参数中必须有一个被设置 // 且如果提供了多个,其优先级为uptoken > uptoken_url > uptoken_func // 其中uptoken是直接提供上传凭证,uptoken_url是提供了获取上传凭证的地址,如果需要定制获取uptoken的过程则可以设置uptoken_func // uptoken : '<Your upload token>', // uptoken是上传凭证,由其他程序生成 // uptoken_url: '/uptoken', // Ajax请求uptoken的Url,强烈建议设置(服务端提供) // uptoken_func: function(file){ // 在需要获取uptoken时,该方法会被调用 // // do something // return uptoken; // }, get_new_uptoken: false, // 设置上传文件的时候是否每次都重新获取新的uptoken // downtoken_url: '/downtoken', // Ajax请求downToken的Url,私有空间时使用,JS-SDK将向该地址POST文件的key和domain,服务端返回的JSON必须包含url字段,url值为该文件的下载地址 // unique_names: true, // 默认false,key为文件名。若开启该选项,JS-SDK会为每个文件自动生成key(文件名) // save_key: true, // 默认false。若在服务端生成uptoken的上传策略中指定了sava_key,则开启,SDK在前端将不对key进行任何处理 domain: '<Your bucket domain>', // bucket域名,下载资源时用到,必需 container: 'container', // 上传区域DOM ID,默认是browser_button的父元素 max_file_size: '100mb', // 最大文件体积限制 flash_swf_url: 'path/of/plupload/Moxie.swf', //引入flash,相对路径 max_retries: 3, // 上传失败最大重试次数 dragdrop: true, // 开启可拖曳上传 drop_element: 'container', // 拖曳上传区域元素的ID,拖曳文件或文件夹后可触发上传 chunk_size: '4mb', // 分块上传时,每块的体积 auto_start: true, // 选择文件后自动上传,若关闭需要自己绑定事件触发上传 //x_vars : { // 查看自定义变量 // 'time' : function(up,file) { // var time = (new Date()).getTime(); // do something with 'time' // return time; // }, // 'size' : function(up,file) { // var size = file.size; // do something with 'size' // return size; // } //}, init: { 'FilesAdded': function(up, files) { plupload.each(files, function(file) { // 文件添加进队列后,处理相关的事情 }); }, 'BeforeUpload': function(up, file) { // 每个文件上传前,处理相关的事情 }, 'UploadProgress': function(up, file) { // 每个文件上传时,处理相关的事情 }, 'FileUploaded': function(up, file, info) { // 每个文件上传成功后,处理相关的事情 // 其中info是文件上传成功后,服务端返回的json,形式如: // { // "hash": "Fh8xVqod2MQ1mocfI4S4KpRL6D98", // "key": "gogopher.jpg" // } // 查看简单反馈 // var domain = up.getOption('domain'); // var res = parseJSON(info); // var sourceLink = domain +"/"+ res.key; 获取上传成功后的文件的Url }, 'Error': function(up, err, errTip) { //上传出错时,处理相关的事情 }, 'UploadComplete': function() { //队列文件处理完毕后,处理相关的事情 }, 'Key': function(up, file) { // 若想在前端对每个文件的key进行个性化处理,可以配置该函数 // 该配置必须要在unique_names: false,save_key: false时才生效 var key = ""; // do something with key here return key } } });

step3:封装组件

1)directive模块:

function wbUpLoad(Core, $timeout) {    return {        restrict: 'AE',        templateUrl: 'views/directive/upLoad.html',        transclude: true,        scope: {            upLoadError: "&",            upLoadProgress: "&",            upLoaded: "&"        },        link: function (scope, elem, attrs) {            $timeout(function () {                if (!attrs.browseButton) {                    attrs.browseButton = 'pickfiles';                }                var pickfiles = $('[browse-button=' + attrs.browseButton + ']').find('.pickfiles');                pickfiles.attr('id', attrs.browseButton);                var context = scope;                var uploader = Qiniu.uploader({                    runtimes: 'html5,flash,html4',                    browse_button: attrs.browseButton,                    container: 'container',                    drop_element: 'container',                    flash_swf_url: 'bower_components/plupload/js/Moxie.swf',                    dragdrop: true,                    chunk_size: '4mb',                    uptoken_url: '/token/qiniu.json',                    multi_selection: false,                     filters: {                        max_file_size: '100000mb',                        prevent_duplicates: true,                        //Specify what files to browse for                        mime_types: [                            // {title : "mp4 files", extensions : "mkv"}                            // {title : "flv files", extensions : "flv,jpg"}                            // {title : "Video files", extensions : "flv,mpg,mpeg,avi,wmv,mov,asf,rm,rmvb,mkv,m4v,mp4"}                            // {title : "Video files", extensions : "avi,mp4,wmv,mpg,mov,flv,mkv,mpeg"}                            // {title : "Image files", extensions : "jpg,gif,png"}                            // {title : "Zip files", extensions : "zip"}                        ]                    },                    domain: 'http://xxxxx.com/',                    get_new_uptoken: false,                    // downtoken_url: '/downtoken',                    unique_names: false,                    // save_key: true,                    x_vars: {                        'time': function (up, file) {                            var time = (new Date()).getTime();                            // do something with 'time'                            return time;                        }                    },                    auto_start: true,                    log_level: 5,                    init: {                        'FilesAdded': function (up, files) {

                        },                        'BeforeUpload': function (up, file) {                            var file_ext = file.name.substr(file.name.lastIndexOf("."));                            uploader.settings.multipart_params.key = parseInt(new Date().valueOf()) + file_ext;                        },                        'UploadProgress': function (up, file) {

                            context.upLoadProgress({info: file});                        },                        'UploadComplete': function () {                        },                        'FileUploaded': function (up, file, info) {

                            context.upLoaded({                                info: {info: info, file: file}                            });                        },                        'Error': function (up, err, errTip) {                            console.log('Error');                            console.log(up);                            console.log(err);                            context.upLoadError({info: err});                        }                    }                });            });        }    }}

2)templateUrl 模块:

<div id="container" style="display: inline-block;" ng-click="onClickGetToken()">    <a class="pickfiles" id="pickfiles" style="display: inline-block;">        <div ng-transclude>        </div>    </a></div>

3)html部分:

<wb-up-load up-load-error="upLoadError(info)" up-loaded="upLoadSuccess(info,packageInItem)"            up-load-progress="upLoadProgress(info)">    <button style="color:#1D76FB;" class="btn btn-default">上传图片</button></wb-up-load>
<img class="small-img"  ng-src="{{valueLabelUrl}}">

4)controller模块:

var context = $scope;context.upLoadSuccess = upLoadSuccess;
function upLoadSuccess(upLoadInfo, item) {    //图片上传成功    item.valueLabelUrl = "http:xxxxx.com/" + JSON.parse(upLoadInfo.info).key;    context.$apply();}

step4:效果预览

上传成功后你只需要拿到对应的key就好了。

ps:这就实现了七牛云图片上传功能,但是由于browse_button固定啦,同一个页面多个上传的按钮都是相同的browse_button id,点击按钮会触发多次上传事件,因此必须动态获取到每个不同按钮的id,并且在组件中赋值,组件中必须使用$timeout在dom渲染完成之后才能获取到对应的browse_button id。

step5:修改组件和html ---------

directive模块:

function wbUpLoad($timeout) {    return {        restrict: 'AE',        templateUrl: 'views/directive/upLoad.html',        transclude: true,        scope: {            upLoadError: "&",            upLoadProgress: "&",            upLoaded: "&"        },        link: function (scope, elem, attrs) {            $timeout(function () {                if (!attrs.browseButton) {                    attrs.browseButton = 'pickfiles';//如果没有attrs.browseButton,id为pickfiles
                }                var pickfiles = $('[browse-button=' + attrs.browseButton + ']').find('.pickfiles');                pickfiles.attr('id', attrs.browseButton);//设置id为html传入的browseButton值                var context = scope;                var uploader = Qiniu.uploader({                    runtimes: 'html5,flash,html4',                    browse_button: attrs.browseButton,                    container: 'container',                    drop_element: 'container',                    flash_swf_url: 'bower_components/plupload/js/Moxie.swf',                    dragdrop: true,                    chunk_size: '4mb',                    uptoken_url: '/token/qiniu.json',                    multi_selection: false,                     filters: {                        max_file_size: '100000mb',                        prevent_duplicates: true,                        //Specify what files to browse for                        mime_types: [                            // {title : "mp4 files", extensions : "mkv"}                            // {title : "flv files", extensions : "flv,jpg"}                            // {title : "Video files", extensions : "flv,mpg,mpeg,avi,wmv,mov,asf,rm,rmvb,mkv,m4v,mp4"}                            // {title : "Video files", extensions : "avi,mp4,wmv,mpg,mov,flv,mkv,mpeg"}                            // {title : "Image files", extensions : "jpg,gif,png"}                            // {title : "Zip files", extensions : "zip"}                        ]                    },                    domain: 'http://xxxxx.com/',                    get_new_uptoken: false,                    // downtoken_url: '/downtoken',                    unique_names: false,                    // save_key: true,                    x_vars: {                        'time': function (up, file) {                            var time = (new Date()).getTime();                            // do something with 'time'                            return time;                        }                    },                    auto_start: true,                    log_level: 5,                    init: {                        'FilesAdded': function (up, files) {

                        },                        'BeforeUpload': function (up, file) {                            var user = Core.Data.getUser();                            var file_ext = file.name.substr(file.name.lastIndexOf("."));                            uploader.settings.multipart_params.key = parseInt(new Date().valueOf()) + file_ext;                        },                        'UploadProgress': function (up, file) {

                            context.upLoadProgress({info: file});                        },                        'UploadComplete': function () {                        },                        'FileUploaded': function (up, file, info) {

                            context.upLoaded({                                info: {info: info, file: file}                            });                        },                        'Error': function (up, err, errTip) {                            console.log('Error');                            console.log(up);                            console.log(err);                            context.upLoadError({info: err});                        }                    }                });            });        }    }}

html部分:

<wb-up-load up-load-error="upLoadError(info)" up-loaded="upLoadSuccess(info,packageInItem)"            up-load-progress="upLoadProgress(info)" browse-button="pickfiles{{$index}}">
    <button style="color:#1D76FB;" class="btn btn-default">上传图片</button></wb-up-load>
<img class="small-img"  ng-src="{{valueLabelUrl}}">

ps:以上修改可以同一页面多个按钮上传图片,如果你想点击图片在重新上传,可以将img写在组件里面,如果你还想实现鼠标移动到图片上预览大图,你可以给img加上鼠标事件,大图使用定位来展示。如:

<img class="small-img" ng-mouseenter="isShowImg=true" ng-mouseleave="isShowImg=false" ng-src="{{packageInItem.valueLabelUrl}}">

参考链接:利用七牛云图片上传总结

  -----原创文章,©版权所有,转载请注明标明出处:http://www.cnblogs.com/doinbean

转载于:https://www.cnblogs.com/doinbean/p/7589168.html

angular封装七牛云图片上传,解决同一页面多个上传按钮分别上传相关推荐

  1. java实现七牛云图片文件的上传

    java实现七牛云图片文件的上传 七牛云:https://portal.qiniu.com/create#resource 首先需要去注册一个账号实现实名认证 之后打开七牛云的 我们需要先创建一个储存 ...

  2. 七牛云图片--Java文档

    七牛云图片–Java文档 简介 此 SDK 适用于 Java 7 及以上版本.使用此 SDK 构建您的网络应用程序,能让您以非常便捷地方式将数据安全地存储到七牛云上.无论您的网络应用是一个网站程序,还 ...

  3. php 必应每日壁纸,GitHub - lylares/todaybing: 必应壁纸七牛云图片站

    PHP 实现必应每日壁纸+七牛云图片站 本程序实现bing每日图片保存在服务器本地,然后自动上传到七牛云空间,在前端界面展现的图片皆从七牛云获取. 更新 2018.04.04 更新: 1.接口以及部分 ...

  4. 仿照七牛云图片处理类实现的C#帮助类

    介绍 Sop.Common.Img 请看 七牛云的图片处理功能介绍文档了解本项目功能 此项目是有https://github.com/Sopcce/.Net-Common-Utility中的一个小部分 ...

  5. 七牛云 图片上传覆盖

    php使用七牛云上传图片,覆盖云上已有文件: 使用七牛云存储提供的PHP SDK,可以非常方便的将本地文件上传到七牛,但默认情况下,上传的文件不会覆盖旧文件,也就是说,之前上传了一个名为photo.j ...

  6. tp框架文件上传七牛服务器,TP5开发 - 七牛云图片上传方法

    1.config.php配置文件里配置七牛云密钥等 里面 secretKey accessKey domain bucket对应换成自己七牛云申请的, 步骤: (1)七牛云注册成功后-对象存储申请10 ...

  7. html七牛云图片文件上传,使用Js将文件图片视频上传到七牛云详细教程-Fun言

    前言 因为项目需要,需要将一些较大文件上传到七牛云,以前都是通过数据流上传到服务端,然后在服务端进行上传操作,因为以前文件都很小所以无所谓,但是要是几百M的文件就不行了,所以就采用前端js直接上传到七 ...

  8. 七牛云图片处理实践之GIF|如何解决GIF流量爆炸问题?

    摘要 图像的格式丰富多彩,既有使用最多的JPEG.PNG .BMP.GIF,也有Google开发的适用于Web的WebP,更有苹果推出的Live Photo.不管是PC端还是移动端,图片一直是流量的大 ...

  9. 如何解决七牛云图片链接失效问题?

    七牛云的免费域名突然回收,没注意看邮件通知,保存在里面的图片都下载不了了T_T连写好的博客都变这样了,需要花点时间重新整理!!! 还有看到大神的解决方案:https://blog.csdn.net/l ...

  10. 七牛 java 加水印_七牛云图片加水印

    目标:用户登录进平台后,他看到的所有图片都要以他的用户名加上水印. 1.首先说下七牛加水印的方法,首先附上官网地址: https://developer.qiniu.com/dora/manual/1 ...

最新文章

  1. HTTP响应头不缓存
  2. 深入讲解 ASP+ 验证
  3. 从0搭建一个Springboot+vue前后端分离项目(三)使用idea进行页面搭建+Element框架
  4. 高能玩家!硬核自制小程序云“肝”动森
  5. 动态规划——莱文斯坦距离
  6. DbVisualizer 12.0.* Ubuntu
  7. floodfill算法 java_OpenCV 3 floodFill(漫水填充)、图片的放大缩小 pyrUp、pyrDown、Resize JAVA OpenCV专题学习10...
  8. Python 爬虫 —— BeautifulSoup
  9. 港顺计算机怎么放音乐,csgo怎么放歌 CSGO内置语音播放歌曲
  10. Swarm Mode服务管理
  11. 系统动力学软件vensim学习之一阶负反馈
  12. .NET:Core源码编译
  13. 总线之地址总线、数据总线、控制总线
  14. 联创机房管理系统服务器密码,高校机房管理系统解决方案.doc
  15. 微分几何学类毕业论文文献都有哪些?
  16. Qml使用阿里字体图标库及FontAwesome字体图标库
  17. HTML Javascript CGI
  18. Netty网络编程第七卷
  19. php项目过段时间就崩溃,apache 运行一段时间出现错误
  20. 神经网络与深度学习第三周-Planar data classification with one hidden layer

热门文章

  1. powerDesign逆向工程Mysql转Oracle
  2. css下拉菜单代码(用纯css实现下拉菜单)
  3. 华为手机usb连接计算机,华为手机USB为什么连接不上电脑(3个方法彻底解决)...
  4. 2022年全国图书参考联盟读秀5.0/4.0/3.0/2.0/1.0书库网盘数据索引在线搜索查询系统搭建教程,可以实现ISBN/SS号/书封面链接/书名/作者/出版社…等信息一键搜索查询
  5. 影子系统 是怎么一回事!-间歇博客
  6. 密码编码学初探——传统加密技术
  7. win10任务栏全透明
  8. android 自定义控件实现3D画廊效果
  9. PHY之MDIO解析
  10. 蓝桥杯试题c语言蛇形填数,2020十月份蓝桥杯B组省赛题解大全(害!附题面文件和部分代码~)...