Vue中关于ElementUI上传组件Upload的整理

一、概要

ElementUI为我们提供了上传组件Upload:(以下功能 ElementUI官网 均有演示)

  • 可以使用 drag 设置点击或者拖拽上传文件。
  • 可以通过 slot 自定义的上传按钮类型和文字提示。
  • 可以通过 limiton-exceed 限制上传文件的个数和定义超出限制时的行为
  • 可以通过 before-remove 来阻止文件移除操作。
  • 可以通过 before-upload 限制用户上传的图片格式和大小。
  • 可以使用 list-type 属性来设置文件列表的样式。
  • 可以使用 scoped-slot 去设置缩略图模版。
  • 可以通过 on-change 钩子函数来对列表进行控制。
  • 可以使用 scoped-slot 去设置缩略图模版。
二、功能梳理

要想学会一个组件怎么使用,首先要了解它的组成,一个组件的组成无非四种类型:
属性(Attribute)、方法(Methods)、事件(Event)、插槽(Slot)

1、Attribute
  • 关于上传的一些请求属性
参数说明类型默认值
action请求地址(必选)String
name请求字段名Stringfile
headers请求头Object
data请求额外参数Object
with-credentials支持发送 cookie 凭证信息Booleanfalse
http-request自定义上传Function
  • 关于上传的一些配置属性
参数说明类型默认值
accept接受上传的文件类型(thumbnail-mode 模式下此参数无效)String
multiple是否支持多选文件Boolean
limit最大允许上传个数Number
show-file-list是否显示已上传文件列表Booleantrue
file-list上传的文件列表, 例如: [{name: ‘food.jpg’, url: ‘https://xxx.cdn.com/xxx.jpg’}]Array—[]
list-type文件列表的类型(text/picture/picture-card)String—text
drag是否启用拖拽上传Booleanfalse
auto-upload是否在选取文件后立即进行上传Booleantrue
disabled是否禁用Booleantrue
  • 关于上传的一些钩子属性
参数说明类型默认值
on-preview点击文件列表中已上传的文件时的钩子function(file)
before-remove删除文件之前的钩子,参数为上传的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,则停止删除。function(file, fileList)
on-remove文件列表移除文件时的钩子function(file, fileList)
before-upload上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。function(file)
on-progress文件上传时的钩子function(event, file, fileList)
on-success文件上传成功时的钩子function(response, file, fileList)
on-error文件上传失败时的钩子function(err, file, fileList)
on-change文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用function(file, fileList)
on-exceed文件超出个数限制时的钩子function(files, fileList)
2、Methods
方法说明参数
clearFiles清空已上传的文件列表(该方法不支持在 before-upload 中调用)
abort取消上传请求( file: fileList 中的 file 对象 )
submit手动上传文件列表
3、Slot
name说明
trigger触发文件选择框的内容
tip提示说明文字
三、代码示例
  • template
  <div>
    <el-upload
      ref="upload"
      :action="action"
      :name="name"
      :headers="headers"
      :data="data"
      :with-credentials="withCredentials"
      :accept="accept"
      :multiple="multiple"
      :limit="limit"
      :show-file-list="showFileList"
      :file-list="fileList"
      :list-type="listType"
      :drag="drag"
      :auto-upload="autoUpload"
      :disabled="disabled"
      :on-preview="handlePreview"
      :before-remove="beforeRemove"
      :on-remove="handleRemove"
      :before-upload="beforeUpload"
      :on-progress="handleProgress"
      :on-success="handleSuccess"
      :on-error="handleError"
      :on-change="handleChange"
      :on-exceed="handleExceed"
    >
      <el-button size="small" type="primary">点击上传</el-button>
      <div slot="trigger">触发文件选择框的内容</div>
      <div slot="tip" class="el-upload__tip">提示说明文字(例如:只能上传jpg/png文件,且不超过500kb</div>
    </el-upload>
    <el-upload :http-request="httpRequest" />
    <el-button size="small" type="primary" @click="emitMethods">实例方法</el-button>
  </div>
  • javascript
export default {
  name: 'Demo',
  data() {
    return {
      action: '', // 请求地址
      name: 'file', // 请求字段名
      headers: {}, // 请求头
      data: {}, // 请求额外参数
      withCredentials: false, // 支持发送 cookie 凭证信息
      accept: '', // 接受上传的文件类型
      multiple: true, // 是否支持多选文件
      limit: 3, // 最大允许上传个数
      showFileList: true, // 是否显示已上传文件列表
      fileList: [], // 上传的文件列表, 例如: [{name: ‘food.jpg’, url: ‘https://xxx.cdn.com/xxx.jpg’}]
      listType: 'text', // 文件列表的类型(text/picture/picture-card)
      drag: false, // 是否启用拖拽上传
      autoUpload: true, // 是否在选取文件后立即进行上传
      disabled: true // 是否禁用

    }
  },
  methods: {
    // 覆盖默认的上传行为
    httpRequest() {
      // 可以自定义上传的实现
    },
    // 点击文件列表中已上传的文件时的钩子
    handlePreview(file) {
      console.log(file)
    },
    // 删除文件之前的钩子,参数为上传的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,则停止删除。
    beforeRemove(file, fileList) {
      console.log(file, fileList)
      return this.$confirm(`确定移除 ${file.name}?`)
    },
    // 文件列表移除文件时的钩子
    handleRemove(file, fileList) {
      console.log(file, fileList)
    },
    // 上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。
    beforeUpload(file) {
      console.log(file)
    },
    // 文件上传时的钩子
    handleProgress(event, file, fileList) {
      console.log(event, file, fileList)
    },
    // 文件上传成功时的钩子
    handleSuccess(response, file, fileList) {
      console.log(response, file, fileList)
      this.$message.success('上传成功!')
    },
    // 文件上传失败时的钩子
    handleError(err, file, fileList) {
      console.log(err, file, fileList)
      this.$message.error('上传失败!')
    },
    // 文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
    handleChange(file, fileList) {
      console.log(file, fileList)
    },
    // 文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
    handleExceed(files, fileList) {
      this.$message.warning(`当前限制选择 3 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`)
    },
    // 实例方法
    emitMethods() {
      // 清空已上传的文件列表(该方法不支持在 before-upload 中调用)
      this.$refs.upload.clearFiles()
      // 取消上传请求,参数:( file: fileList 中的 file 对象 )
      this.$refs.upload.abort()
      // 手动上传文件列表
      this.$refs.upload.submit()
    }
  }
}
参考文档
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在 vue-quill-editor 组件的配置项添加一个自定义的图片上传方法。你可以使用 element-ui 的上传组件来实现上传操作。 在 vue-quill-editor 组件添加如下配置项: ```javascript <template> <quill-editor ... :options="editorOption" /> </template> <script> import { Upload } from 'element-ui'; export default { data() { return { editorOption: { modules: { toolbar: { ... handlers: { image: this.customImageHandler } } } } } }, methods: { customImageHandler() { const input = document.createElement('input'); input.setAttribute('type', 'file'); input.setAttribute('accept', 'image/*'); input.onchange = () => { const file = input.files[0]; const formData = new FormData(); formData.append('file', file); Upload.request({ url: 'your-upload-api-url', method: 'post', data: formData, headers: { Authorization: 'Bearer ' + localStorage.getItem('token') // 如果需要携带认证信息 } }).then(res => { const url = res.data.url; // 根据你的上传 API 返回的数据结构获取图片 URL const quill = this.$refs.quillEditor.quill; const range = quill.getSelection(true); quill.insertEmbed(range.index, 'image', url); quill.setSelection(range.index + 1); }); }; input.click(); } } } </script> ``` 在上述代码,我们使用 `handlers` 配置项来添加自定义的图片上传操作,即 `customImageHandler` 方法。该方法会创建一个 `input` 标签来触发文件选择框,用户选择图片后,使用 element-ui 的上传组件上传图片,并根据上传结果在编辑器插入图片。 需要注意的是,你需要根据你的实际情况修改上传 API 的 URL,以及上传成功后返回的图片 URL 在响应数据的字段名。另外,如果你的上传 API 需要携带认证信息,可以在请求头添加相应的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值