vant van-uploader上传file文件;回显时使用imageId拼接路径

上传

form.startOutsideSign.outsideSignPhotoFile是数组

复制代码
 <van-field name="startUploader"
                                    :rules="[{ validator: uploaderValidator, message: '请上传出发地照片' }]" required>
                                    <template #input>
                                        <van-uploader v-model="form.startOutsideSign.outsideSignPhotoFile"
                                            capture="camera" :max-count="1" :deletable="!formReadonly"
                                            :disabled="formReadonly" :after-read="afterReadStart"
                                            @delete="afterReadStart" />
                                    </template>
                                </van-field>

根据项目而定的校验

复制代码
    // 自定义上传组件的校验函数
        uploaderValidator(fileList) {
            // 如果当前是"提交"操作,则必须有文件
            if (this.currentActionType === 'submit') {
                return fileList && fileList.length > 0;
            }
            // 如果是其他操作(如保存),则直接通过校验
            return true;
        },

      afterReadStart(file) {
            console.log('新上传的文件:', file);
            // 应该清除原来的数据 
            this.form.startOutsideSign.imageId = '';
            // todo! 时间 地点
        },

提交代码时,因为要求outsideSignPhotoFile是[file,file...]的格式,如果不是file文件,即是后端返回的图片,如含imageId,就不另外处理,

复制代码
     startOutsideSign.outsideSignPhotoFile = startOutsideSign.outsideSignPhotoFile.filter(ele => ele.file).map(ele => {
                        if (ele.file) {
                            return ele.file
                        }
                        return ele
                    })

回显

复制代码
  if (_startOutsideSign) {
                    _startOutsideSign.outsideSignPhotoFile = _startOutsideSign.imageId ? this.transformFileListByImageId(_startOutsideSign.imageId) : []
                }


        transformFileListByImageId(imageId) {

            return [
                {
                    url: this.imgUrl + imageId,
                    // 可以存储原始imageId,方便后续操作
                    isServerImage: true,
                    imageId,
                    isImage: true // 明确告诉Vant这是一个图片
                }
            ]
        },
相关推荐
skilllite作者3 分钟前
GEO 是什么:从搜索引擎到「对话式答案」的信息可见性
java·前端·笔记·安全·搜索引擎·agentskills
Hello--_--World6 分钟前
React:useState 函数式更新、useContext 全解析、useReducer 深度解析
前端·react.js·前端框架
李白的天不白9 分钟前
vue优化建议
前端·javascript·vue.js
前端老石人12 分钟前
Chrome DevTools 调试入门:从零开始排查 CSS 问题
前端·css·chrome devtools
恋猫de小郭15 分钟前
经典,Flutter iOS 又修复了一个构建问题,还是很抽象
android·前端·flutter
invicinble20 分钟前
前端框架使用vue-cli(总篇章介绍)
前端·vue.js·前端框架
QD_ANJING24 分钟前
普及一下五月AI前端面试需要达到的强度....
前端·javascript·vue.js·人工智能·面试·职场和发展
AI自动化工坊24 分钟前
Chrome DevTools MCP:让AI编码代理获得浏览器调试能力
前端·人工智能·chrome devtools
ZC跨境爬虫26 分钟前
跟着 MDN 学 HTML day_26:(DOM 的树形结构与节点导航)
前端·ui·html·音视频·视频编解码
2601_9534656133 分钟前
纯前端高性能!m3u8live.cn 重新定义 M3U8 在线播放与调试体验
开发语言·前端·javascript·m3u8