antDesignVue中a-upload上传组件的使用

工作中需要使用上传组件,记录一下a-upload部分属性用法
1.showUploadList属性使用

使用:showUploadList="{ showRemoveIcon: true ,showDownloadIcon: true }"属性可控制右侧下载,删除图标

2.如何实现回显功能

使用:defaultFileList="fileList" 格式传入参数实现

在编辑时需要回显附件信息,但是后端传参可能不符合组件标准接参数格式,导致无法回显

javascript 复制代码
 // 编辑
    modifyFn(row) {
      this.fileList == []
      this.drawerTitle = "编辑"
      console.log(row);
      this.form = { ...row };
      // 使用 map 方法统一转换为标准的 fileList 格式
      const standardFileList = row.attachList.map(item => ({
        uid: item.id, // 使用原始数据的 id 作为 uid
        name: item.fileName, // 使用原始数据的 fileName 作为文件名称
        status: 'done', // 文件状态,已完成
        url: item.filePath //`your_base_url/${item.filePath}` // 构建文件的访问 URL,需替换 your_base_url 为实际的文件存储基础 URL
      }));
      this.fileList = Object.assign([], standardFileList).map(item => {
        return Object.assign({}, item)
      })
      console.log("编辑传参", this.fileList);
      this.visible = true;
    },

可拖入上传附件组件代码

javascript 复制代码
 <a-form-model-item
              label="附件"
              :label-col="{ span: 4 }"
              :wrapper-col="{ span: 20 }"
            >
              <a-upload-dragger
              accept = "image"
                name="files"
               :action="uploadAction"
                listType="picture"
                :defaultFileList="fileList"
                @change="handleChange2"
                :showUploadList="{ showPreviewIcon: true,showRemoveIcon: true ,showDownloadIcon: true }"
              >
                <!-- :multiple="true"   -->
                <p class="ant-upload-drag-icon">
                  <a-icon type="inbox" />
                </p>
                <p class="ant-upload-text">
                  选择文件或拖入文件
                </p>
              </a-upload-dragger>
            </a-form-model-item>

在data中设置上传url地址

javascript 复制代码
data() {
   return {
           uploadAction: "/uploadUrl",
   }
}

在change事件中可对上传文件数据进行操作

相关推荐
fanruitian10 分钟前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo13 分钟前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk17 分钟前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
摘星编程1 小时前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_944525542 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin1233222 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos
李白你好2 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
经年未远3 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue
刘一说3 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
可触的未来,发芽的智生4 小时前
狂想:为AGI代称造字ta,《第三类智慧存在,神的赐名》
javascript·人工智能·python·神经网络·程序人生