Upload 上传
优质
小牛编辑
131浏览
2023-12-01
通过点击或者拖拽上传文件
点击上传
[upload-filter]
是用于上传过滤的中间件,你可以根据此自定义一些标准,返回 false
会阻止上传动作。
<el-upload action="http://jsonplaceholder.typicode.com/posts" [file-list]="fileList" [upload-filter]="limit500.bind(this)"> <ng-template #trigger> <el-button size="small" type="primary">点击上传2</el-button> </ng-template> <ng-template #tip> <div class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> </ng-template> </el-upload> <script type="text"> // in component, file is native file limit500(file: File): boolean { if (file.size > 500000) { this.message.info('文件超过了 500 kb.') return false } return true } </script>
用户头像上传
<el-upload class="avatar-uploader" action="https://jsonplaceholder.typicode.com/posts/" [show-file-list]="false" (success)="successHandle($event)" (error)="errorHandle($event)"> <ng-template #trigger> <img *ngIf="imageUrl" [src]="imageUrl" class="avatar"> <i *ngIf="!imageUrl" class="el-icon-plus avatar-uploader-icon"></i> </ng-template> </el-upload> <script type="text"> // in component, file is native file successHandle(file: any): void { this.imageUrl = this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file.raw)) this.message.info('文件上传成功') } errorHandle(err: any): void { this.message.error('文件上传失败:' + err) } </script>
照片墙
使用 list-type
属性来设置文件列表的样式。
移除或是点击等操作都可以 获得相应的事件,事件参数请参见文末属性表。
<el-upload action="https://jsonplaceholder.typicode.com/posts/" list-type="picture-card" (preview)="previewHandle($event)" (remove)="removeHandle($event)"> <ng-template #trigger> <i class="el-icon-plus"></i> </ng-template> </el-upload> <el-dialog [(visible)]="showDialog" size="tiny"> <img width="100%" [src]="dialogImageUrl" alt=""> </el-dialog>
图片列表缩略图
[list-type]
的改变只是样式与布局上的,所有类型的事件与参数都是相同的。
<el-upload class="avatar-uploader" [file-list]="fileList" action="https://jsonplaceholder.typicode.com/posts/" list-type="picture"> <ng-template #trigger> <el-button size="small" type="primary">点击上传</el-button> </ng-template> </el-upload>
拖拽上传
设置 [drag]
为 true
即可开启拖拽模式。
<el-upload class="upload-demo" action="https://jsonplaceholder.typicode.com/posts/" [drag]="true" [multiple]="true"> <ng-template #trigger> <i class="el-icon-upload"></i> <div class="el-upload__text">将文件拖到此处,或 <em>点击上传</em> </div> </ng-template> </el-upload>
Upload Attributes
参数 | 说明 | 类型 | 可选值 | 默认值 |
---|---|---|---|---|
action | 必选参数, 上传的地址 | string | ||
headers | 可选参数, 设置上传的请求头部 | object | ||
multiple | 可选参数, 是否支持多选文件 | boolean | ||
with-credentials | 支持发送 cookie 凭证信息 | boolean | ||
show-file-list | 是否显示已上传文件列表 | boolean | 1 | |
drag | 是否启用拖拽上传 | boolean | ||
accept | 可选参数, 接受上传的 文件类型 | string | ||
preview | 可选参数, 点击已上传的文件链接时的事件 | EventEmitter, CommonFile: { id: string, size: number,status: string,name: string,raw: File,url?: SafeUrl, percentage?: number } | ||
remove | 可选参数, 文件列表移除文件时的事件 | EventEmitter | ||
progress | 可选参数, 文件上传的进度事件 | EventEmitter | ||
success | 可选参数, 文件上传成功时的事件 | EventEmitter<{ commonFile: CommonFile, response: HttpResponse }> | ||
error | 可选参数, 文件上传失败时的事件 | EventEmitter | ||
upload-filter | 上传前的过滤函数,你可以根据参数中的文件对象来过滤,返回 false 可阻止文件上传。 | (f: File) => boolean | f => true | |
list-type | 文件列表展示方式 | string | text / picture / picture-card | text |
file-list | 已上传的文件列表 | Array | ||
elDisabled | 是否禁用 | boolean |