angular fileUploader 中文API

Directives(指令)
nv-file-drop
<!-- 最少配置 -->
<elementnv-file-dropuploader="{FileUploader}"></element>
<!-- 最多配置 -->
<elementnv-file-dropuploader="{FileUploader}"options="{Object}"filters="{String}"></element>
属性 uploader 必须是 FileUploader的一个实例。
属性 options 可能是 {FileItem} 的设置或者自定义设置。
属性 filters 可能是用,隔开的过滤器名称,比如: 'filterName1,filterName2',这些过滤器必须如下预定义:
uploader.filters.push({name:'filterName1',fn:function() {/* your code here */}});
uploader.filters.push({name:'filterName2',fn:function() {/* your code here */}});
nv-file-select
<!-- 最少配置 -->
<inputtype="file"nv-file-selectuploader="{FileUploader}"/>
<!-- 最多配置 -->
<inputtype="file"nv-file-selectuploader="{FileUploader}"options="{Object}"filters="{String}"/>
nv-file-over
<!-- 最少配置 -->
<elementnv-file-overuploader="{FileUploader}"></element>
<!-- 最多配置 -->
<elementnv-file-overuploader="{FileUploader}"over-class="{String}"></element>
Service(服务)
FileUploader
FileUploader
属性
url {String}: 上传文件的服务器路径
alias {String}:  包含文件名称,默认是file
queue {Array}: 上传队列
progress {Number}: 上传队列的进度,只读
headers {Object}: 上传的头文件信息, 浏览器需支持HTML5
formData {Array}: 与文件一起发送的表单数据
filters {Array}: 在文件加入上传队列之前应用过滤器.,如果过滤器返回true则文件加入队列中
autoUpload {Boolean}: 文件加入队列之后自动上传,默认是false
method {String}: 请求方式,默认是POST,浏览器需支持HTML5
removeAfterUpload {Boolean}: 文件上传成功之后从队列移除,默认是false
isHTML5 {Boolean}: 如果浏览器支持HTML5上传则返回true,只读
isUploading {Boolean}: 文件正在上传中返回true,只读
queueLimit {Number} : 最大上传文件数量(预定义)
withCredentials {Boolean} : 使用CORS,默认是false, 浏览器需支持HTML5
方法
addToQueue function(files[,options[,filters]]) {: Add items to the queue,where files is a {FileList|File|HTMLInputElement},options is an {Object} andfilters is a {String}.  添加项到上传队列中,files 是 {FileList|File|HTMLInputElement}, options 是 {Object} 以及 filters 是 {String}
removeFromQueue function(value) {: Remove an item from the queue,wherevalue is {FileItem} or index of item.  从上传队列移除项,value 可以是 {FileItem} 或者项的序号
clearQueue function() {: Removes all elements from the queue.  移除上传队列所有的元素
uploadItem function(value) {: Uploads an item,where value is {FileItem} or index of item.  上传项, value 可以是 {FileItem} 或者项的序号
cancelItem function(value) {: Cancels uploading of item,where value is{FileItem} or index of item.  取消上传的项
uploadAll function() {: Upload all pending items on the queue.  将上传队列中所有的项进行上传
cancelAll function() {: Cancels all current uploads.  取消所有当前上传
destroy function() {: Destroys a uploader. 
isFile function(value) {return {Boolean};}: Returns true if value is {File}. 
isFileLikeObject function(value) {return {Boolean};}: Returns true if value is{FileLikeObject}.
getIndexOfItem function({FileItem}) {return {Number};}: Returns the index of the{FileItem} queue element.  返回项在上传队列中的序号
getReadyItems function() {return {Array.<FileItems>};}: Return items are ready to upload.  返回准备上传的项
getNotUploadedItems function() {return {Array.<FileItems>};}: Return an array of all pending items on the queue  返回上传队列中未上传的项
回调函数
onAfterAddingFile function(item) {: 添加文件上传队列后
onWhenAddingFileFailed function(item,filter,options) {: 添加文件上传队列失败后
onAfterAddingAll function(addedItems) {: 添加所选的所有文件上传队列后
onBeforeUploadItem function(item) {: 文件上传之前
onProgressItem function(item,progress) {: 文件上传中
onSuccessItem function(item,response,status,headers) {: 文件上传成功后
onErrorItem function(item,headers) {: 文件上传失败后
onCancelItem function(item,headers) { - 文件上传取消后
onCompleteItem function(item,headers) {: 文件上传完成后
onProgressAll function(progress) {: 上传队列的所有文件上传中
onCompleteAll function() {: 上传队列的所有文件上传完成后

成功上传文件的回调函数顺序是:onAfterAddingFile — onAfterAddingAll — onBeforeUploadItem — onProgressItem — onProgressAll — onSuccessItem — onCompleteItem — onCompleteAll
FileItem
属性
url {String}: Path on the server in which this file will be uploaded  上传文件的服务器路径
alias {String}: Name of the field which will contain the file,default is file  包含文件名称,默认是file
headers {Object}: Headers to be sent along with this file. HTML5 browsers only.  上传的头文件信息, 浏览器需支持HTML5
formData {Array}: Data to be sent along with this file  与文件一起发送的表单数据
method {String}: It's a request method. By default POST. HTML5 browsers only.  请求方式,默认是POST,浏览器需支持HTML5
withCredentials {Boolean} : enable CORS. HTML5 browsers only.  使用CORS,默认是false, 浏览器需支持HTML5
removeAfterUpload {Boolean}: Remove this file from the queue after uploading  上传之后从上传队列移除该文件
index {Number} - A sequence number upload. Read only.  上传文件上传队列中的序号,只读
progress {Number}: File upload progress percentage. Read only.  文件上传的进度,只读
isReady {Boolean} - File is ready to upload. Read only.  文件是否准备好上传,只读
isUploading {Boolean}: true if the file is being uploaded. Read only.  文件是否正在上传中,只读
isUploaded {Boolean}: true if the file was uploaded. Read only.  文件是否已经上传,只读
isSuccess {Boolean}: true if the file was uploaded successfully. Read only.  文件是否已经上传成功,只读
isCancel {Boolean} : true if uploading was canceled. Read only.  文件是否取消上传,只读
isError {Boolean} - true if occurred error while file uploading. Read only.  文件是否上传错误,只读
uploader {Object}: Reference to the parent Uploader object for this file. Read only.  上传文件的Uploader ,只读
方法
remove function() {: Remove this file from the queue  从上传队列移除该文件
upload function() {: Upload this file  上传文件
cancel function() {: Cancels uploading of this file  取消上传文件
回调函数
onBeforeUpload function() {: Fires before uploading an item.  上传文件之前
onProgress function(progress) {: On file upload progress.  上传文件的过程
onSuccess function(response,headers) {: On file successfully uploaded  成功上传文件后
onError function(response,headers) {: On upload error  上传文件出错后
onCancel function(response,headers) { - On cancel uploading  取消上传文件后
onComplete function(response,headers) {: On file upload complete (independently of the sucess of the operation)  完成上传文件后
Filters(过滤器)
注册过滤器:
var uploader =newFileUploader({
    filters: [{
        name:'yourName1',// A user-defined filterfn:function(item) {
            returntrue;
        }
    }]
});

// 另一种
uploader.filters.push({
    name:'yourName2',fn:function(item) {
        returntrue;
    }
});
预定义的过滤器:
folder
queueLimit

github地址: https://github.com/nervgh/angular-file-upload/wiki/Module-API

全部教程: http://each.sinaapp.com/angular/index.html

API使用举例:

var uploader = $scope.uploader = new FileUploader({
    url: $scope.fileUploadUrl
  });

  uploader.filters.push({
    name: 'customFilter',fn: function(item,options) {
      if(item.size > 100*1024*1024){
        toaster.pop("error","错误","文件过大,请限制文件在100M以内");
        return false;
      }
      return true;
    }
  });
  uploader.onAfterAddingFile = function(item){
    item.url = $scope.fileUploadUrl;
    angular.forEach(uploader.queue,function(f){
      if(f.file.name != item.file.name)uploader.removeFromQueue(f);
    })
  }
  uploader.onBeforeUploadItem = function(item){
    toaster.clear();
    toaster.pop("wait","信息","文件正在上传,请稍等....");
  }
  uploader.onSuccessItem = function(item,headers) {
    toaster.clear();
    if(response.result == 1){
      var zTree = $.fn.zTree.getZTreeObj("ztree");
      zTree.addNodes($scope.selectNode,{id:response.obj.id,pId:$scope.selectNode.id,name:response.obj.name});
      toaster.pop("success","文件上传并解析成功");
    } else toaster.pop("error",response.msg);
  };

FileUploader完整使用案例:http://nervgh.github.io/pages/angular-file-upload/examples/simple/

相关文章

AngularJS 是一个JavaScript 框架。它可通过 注:建议把脚本放在 元素的底部。这会提高网页加载速度,因...
angluarjs中页面初始化的时候会出现语法{{}}在页面中问题,也即是页面闪烁问题。出现这个的原因是:由于...
AngularJS 通过被称为指令的新属性来扩展 HTML。AngularJS 指令AngularJS 指令是扩展的 HTML 属性,带有...
AngularJS 使用表达式把数据绑定到 HTML。AngularJS 表达式AngularJS 表达式写在双大括号内:{{ expres...
ng-repeat 指令可以完美的显示表格。在表格中显示数据 {{ x.Name }} {{ x.Country }} 使用 CSS 样式为了...
$http是 AngularJS 中的一个核心服务,用于读取远程服务器的数据。读取 JSON 文件下是存储在web服务器上...