Upload 上传

优质
小牛编辑
125浏览
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是否显示已上传文件列表boolean1
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) => booleanf => true
list-type文件列表展示方式stringtext / picture / picture-cardtext
file-list已上传的文件列表Array
elDisabled是否禁用boolean