标签:xls opp 标签 data- 函数 alias 业务 code 包含
在Github上找到了一个支持Angular4好用的文件上传组件ng2-file-upload
,这里简单介绍一下这个库的集成使用方案。
本文基于该组件的1.2.1
版。
安装非常简单,只要在项目根路径下运行如下npm命令即可:
npm install ng2-file-upload --save
官方的文档写的非常简单,几乎看不出什么来,这里结合实际的使用调试,说明一下基本的配置和使用方案。
在需要使用的Module中需要引入如下两个模块:
…
import { CommonModule } from ‘@angular/common‘;
import { FileUploadModule } from ‘ng2-file-upload‘;
…
@NgModule({
…
imports: [
…
CommonModule,
FileUploadModule
…
],
…
})
export class ProjectDetailPageModule {}
在对应的使用的Component中,需要引入FileUploader
:
import { FileUploader } from ‘ng2-file-upload‘;
然后声明一个FileUploader
类型的变量,并将其初始化:
uploader:FileUploader = new FileUploader({
url: commonConfig.baseUrl + "/uploadFile",
method: "POST",
itemAlias: "uploadedfile",
autoUpload: false
});
初始化FileUploader
需要传入FileUploaderOptions
类型的参数:
参数名 | 参数类型 | 是否是可选值 | 参数说明 |
---|---|---|---|
allowedMimeType | Array | 可选值 | |
allowedFileType | Array | 可选值 | 允许上传的文件类型 |
autoUpload | boolean | 可选值 | 是否自动上传 |
isHTML5 | boolean | 可选值 | 是否是HTML5 |
filters | Array | 可选值 | |
headers | Array | 可选值 | 上传文件的请求头参数 |
method | string | 可选值 | 上传文件的方式 |
authToken | string | 可选值 | auth验证的token |
maxFileSize | number | 可选值 | 最大可上传文件的大小 |
queueLimit | number | 可选值 | |
removeAfterUpload | boolean | 可选值 | 是否在上传完成后从队列中移除 |
url | string | 可选值 | 上传地址 |
disableMultipart | boolean | 可选值 | |
itemAlias | string | 可选值 | 文件标记/别名 |
authTokenHeader | string | 可选值 | auth验证token的请求头 |
this.uploader = new FileUploader({
url: commonConfig.baseUrl + "/uploadFile",
method: "POST",
itemAlias: "uploadedfile",
autoUpload: false,
headers:[
{name:"x-AuthenticationToken",value:"dd32fdfd32fs23fds9few"}
]
});
uploader.uploadAll()
或者uploader.uploadItem(value: FileItem)
方法进行手工上传。allowedFileType: 这个文件类型并非我们认为的文件后缀,不管选择哪一个值,并不会过滤弹出文件选择时显示的文件类型,只是选择后,非该类型的文件会被过滤掉,例如allowedFileType:["image","xls"]
,可选值为:
allowedMimeType: 这个是通过Mime类型进行过滤,例如allowedMimeType: [‘image/jpeg‘, ‘image/png‘ ]
,跟上面的allowedFileType
参数一样,不管选择哪一个值,并不会过滤弹出文件选择时显示的文件类型,只是选择后,非该类型的文件会被过滤掉。
注意基于uploader
事件绑定的函数其默认scope为uploader
自身,所以如果想在对应的绑定函数中使用其他scope对象,需要使用bind
函数处理对应的绑定函数,如下:
this.uploader.onSuccessItem = this.successItem.bind(this);
下面介绍三个常用的事件
onAfterAddingFile(fileItem: FileItem): any;
onSuccessItem(item: FileItem, response: string, status: number, headers: ParsedResponseHeaders): any;
onBuildItemForm(fileItem: FileItem, form: any): any;
this.uploader.onBuildItemForm = this.buildItemForm;
…
buildItemForm(fileItem: FileItem, form: any): any{
if(!!fileItem["realFileName"]){
form.append("fileName",fileItem["realFileName"]);
}
}
input file
控件处理在组件对应的HTML模版中设置input
标签:
<input type="file" ng2FileSelect [uploader]="uploader" (change)="selectedFileOnChanged($event)" />
在组件.ts文件中设置声明函数:
selectedFileOnChanged() {
// 这里是文件选择完成后的操作处理
}
选择文件默认支持选择单个文件,如需支持文件多选,请在标签中添加multiple属性,即:
<input type="file" ng2FileSelect [uploader]="uploader" (change)="selectedFileOnChanged($event)" multiple />
下面是参考官方示例改造的一个文件多选时的template及相关后台代码的配置示例:
<ion-card>
<ion-card-header>
文件上传操作
</ion-card-header>
<ion-card-content>
<input #fileUpload hidden=true type="file" ng2FileSelect [uploader]="uploader" (change)="selectedFileOnChanged($event)" multiple />
<button (click)="fileSelect()" >选择文件</button>
<button (click)="fileAllUp()" >全部上传</button>
<button (click)="fileAllCancel()" >全部取消</button>
<button (click)="fileAllDelete()" >清除列表</button>
</ion-card-content>
</ion-card>
<ion-card>
<ion-card-header>
上传文件列表
</ion-card-header>
<ion-card-content>
<p>已选文件数量: {{ uploader?.queue?.length }}</p>
<ion-grid>
<ion-row>
<ion-col col-2="">名称</ion-col>
<ion-col col-2="">保存名</ion-col>
<ion-col col-2="">文件大小</ion-col>
<ion-col col-2="">进度</ion-col>
<ion-col col-1="">状态</ion-col>
<ion-col col-3="">操作</ion-col>
</ion-row>
<ion-row *ngFor="let item of uploader.queue">
<ion-col col-2><strong>{{ item?.file?.name }}</strong></ion-col>
<ion-col col-2><input type="text" (change)="changeFileName($event, item)"></ion-col>
<ion-col col-2>
<span>{{ item?.file?.size/1024/1024 | number:‘.2‘ }} MB</span>
</ion-col>
<ion-col col-2>
<div class="progress" style="margin-bottom: 0; height: 70%; width: 90%">
<div class="progress-bar" style="margin-bottom: 0; height: 100%; background-color: red" role="progressbar" [ngStyle]="{ ‘width‘: item.progress + ‘%‘ }"></div>
</div>
</ion-col>
<ion-col col-1>
<span *ngIf="item.isSuccess">成功</span>
<span *ngIf="!item.isUploaded">未上传</span>
<span *ngIf="item.isCancel">取消</span>
<span *ngIf="item.isError">错误</span>
</ion-col>
<ion-col col-3>
<button (click)="item.upload()" [disabled]="item.isReady || item.isUploading || item.isSuccess">
上传
</button>
<button (click)="item.cancel()" [disabled]="!item.isUploading">
取消
</button>
<button (click)="item.remove()">
清除
</button>
</ion-col>
</ion-row>
</ion-grid>
</ion-card-content>
</ion-card>
@ViewChild(‘firstInput‘, { read: MdInputDirective })
firstInput: MdInputDirective;
@ViewChild(‘fileUpload‘)
fileUpload: ElementRef;
…
this.uploader = new FileUploader({
url: commonConfig.baseUrl + "/uploadFile",
method: "POST",
itemAlias: "uploadedfile",
autoUpload: false
});
this.uploader.onSuccessItem = this.successItem.bind(this);
this.uploader.onAfterAddingFile = this.afterAddFile;
this.uploader.onBuildItemForm = this.buildItemForm;
…
fileSelect(): any{
this.fileUpload.nativeElement.click();
}
fileAllUp(): any{
this.uploader.uploadAll();
}
fileAllCancel(): any{
this.uploader.cancelAll();
}
fileAllDelete(): any{
this.uploader.clearQueue();
}
selectedFileOnChanged(event) {
// 这里是文件选择完成后的操作处理
}
buildItemForm(fileItem: FileItem, form: any): any{
if(!!fileItem["realFileName"]){
form.append("fileName",fileItem["realFileName"]);
}
}
afterAddFile(fileItem: FileItem): any{
}
changeFileName(value: any, fileItem: FileItem){
fileItem["realFileName"] = value.target.value;
}
successItem(item: FileItem, response: string, status: number, headers: ParsedResponseHeaders):any{
// 上传文件成功
if (status == 200) {
// 上传文件后获取服务器返回的数据
let tempRes = JSON.parse(response);
}else {
// 上传文件后获取服务器返回的数据错误
}
console.info(response+" for "+item.file.name + " status " + status);
}
一下内容引用自参考文件Angular2使用ng2-file-upload上传文件
拖拽文件默认支持多文件拖拽。
对块级元素进行设置(这里以div标签为例):
<div class="beforeDrop" ng2FileDrop [ngClass]="{dropping: isDropZoneOver}" (fileOver)="fileOverBase($event)" (onFileDrop)="fileDropOver($event)" [uploader]="uploader"><div>
在组件.ts
文件中设置声明函数:
fileOverBase(event) {
// 拖拽状态改变的回调函数
}
fileDropOver(event) {
// 文件拖拽完成的回调函数
}
FileUploader
是ng2-file-upload
最主要的部件,里面包含了所有对文件的处理。
FileItem
是FileUploader
中queue
属性的元素类型,在FileUploader
中存储的文件的基本类型。
标签:xls opp 标签 data- 函数 alias 业务 code 包含
原文地址:http://www.cnblogs.com/gavin-cn/p/7256852.html