vue+elementUI,实现表单验证中的图片上传验证(el-form与el-upload)

在实现表单的过程中需要上传商品图片、二维码、头像等,需求是每次只能上传一张图片,并且需要进行相关的非空验证,操作演示如下图所示:

  1. 点击图片上传,清空验证结果,并且修改验证对象kfFormRules,移除里面关于头像上传的条件headImg,这些逻辑需要在on-change中去实现,然后在点击确定就不会有关于headImg的验证,具体可以看上图标出的控制台提示。

  2. 在点击删除图片时on-remove,需要把验证规则重新加回来

  3. 在重置按钮的clearAll()方法中,判断headFileList的数组长度是否大于0,因为已经做了限制这个数组的长度不是0就是1,当它大于0的时候,移除数组中的值,然后将他作为第二个参数传入remove()方法中,小伙伴们肯定有疑问了,为什么不直接传一个空数组,更简单更方便,经测试如果直接传一个空数组,无法移除图片,所以采取了先获取再删除的方式。

代码如下:

<template>
    <!-- 商品详情界面 -->
    <div>
        <!-- 面包屑导航区域 -->
        <breadcrumb></breadcrumb>
        
        <!-- 卡片视图区域 -->
        <el-card>
            <div slot="header">
                <span>基本信息</span>
            </div>
            <el-form label-width="120px" :model="kfForm" ref="kfFormRef" :rules="kfFormRules">
                <el-form-item label-width="0px" prop="name">
                    <el-input placeholder="客服名称" v-model="kfForm.name">
                        <template slot="prepend">客服名称</template>
                    </el-input>
                </el-form-item>
                <el-form-item label-width="0px" prop="wx_number">
                    <el-input placeholder="微信号" v-model="kfForm.wx_number">
                        <template slot="prepend">微信号码</template>
                    </el-input>
                </el-form-item>
                <el-form-item label="客服头像上传:" prop="headImg">
                    <el-upload
                        :action="uploadURL"
                        list-type="picture-card"
                        :class="{hide:hideUpload}"
                        name="files"
                        :on-preview="handlePreview"
                        :on-remove="remove"
                        :on-change="uploadChange"
                        :http-request="headUpload">
                        <i class="el-icon-plus"></i>
                    </el-upload>
                    <el-dialog :visible.sync="previewVisible">
                        <img width="100%" :src="previewPath" alt="">
                    </el-dialog>
                </el-form-item>
                 <el-form-item label="微信二维码上传:" prop="codeImg">
                    <el-upload
                        :action="uploadURL"
                        list-type="picture-card"
                        :class="{hide:hideCode}"
                        name="files"
                        :on-preview="codePreview"
                        :on-remove="codeRemove"
                        :on-change="codeChange"
                        :http-request="codeUpload">
                        <i class="el-icon-plus"></i>
                    </el-upload>
                    <el-dialog :visible.sync="codeVisible">
                        <img width="100%" :src="codePath" alt="">
                    </el-dialog>
                </el-form-item>
                <el-form-item>
                    <el-button type="primary" @click="certain">确 定</el-button>
                    <el-button type="primary" @click="clearAll">重 置</el-button>
                </el-form-item>
            </el-form>
        </el-card>
    </div>
</template>

<script>
import axios from 'axios' 
import breadcrumb from "../../components/breadcrumb/breadcrumb";
export default {
    components: {
        breadcrumb,
    },
    data() {
        return {
            // 上传图片的URL地址
            uploadURL: '',
            previewPath: '',
            previewVisible: false,
            codePath: '',
            codeVisible: false,
            hideUpload: false,
            hideCode: false,
            limitCount: 1,
            limitCode: 1,
            headImg: [],//头像
            wxImg: [],//微信二维码
            kfForm: {
                name: '',
                wx_number: '',
            }, //分佣弹框的表单对象
            // 表单校验规则
            kfFormRules: {
                name: [
                    { required: true, message: '请输入客户专员名称', trigger: 'blur' },
                ],
                wx_number: [
                    { required: true, message: '请输入客服专员微信号', trigger: 'blur' },
                ],
                headImg: [{ required: true, message: '请上传客服头像', trigger: 'change'}],
                codeImg: [{ required: true, message: '请上传微信二维码', trigger: 'change'}],
            },
            headFile: '',
            headFileList: '',
            codeFile: '',
            codeFileList: '',
        }
    },
    methods: {
        headUpload(params) {
            let param = new FormData();
            param.append("files", params.file);
            axios({
                url: this.adminConfig.uploadPath+"upload/upload/",
                method: "post",
                data: param,
                headers: {
                    "Content-Type": "multipart/form-data"
                }
            }).then(res => {
                this.headImg = [];
                this.headImg.push(res.data.data)
            })
        },
        codeUpload(params) {
            let param = new FormData();
            param.append("files", params.file);
            axios({
                url: this.adminConfig.uploadPath+"upload/upload/",
                method: "post",
                data: param,
                headers: {
                    "Content-Type": "multipart/form-data"
                }
            }).then(res => {
                this.wxImg = [];
                this.wxImg.push(res.data.data)
            })
        },
        // 处理图片预览效果
        handlePreview(file) {
            this.previewPath = file.url;
            this.previewVisible = true
        },
        remove(file, fileList) {
            if(fileList.length==0){
                this.kfFormRules.headImg = [{ required: true, message: '请上传微信头像', trigger: 'change'}];
            }
            this.hideUpload = fileList.length >= this.limitCount;
        },
        uploadChange(file, fileList) {
            this.headFile = file;
            this.headFileList = fileList;
            if(fileList.length==1) {
                let {headImg, ...data} = this.kfFormRules;
                this.kfFormRules = data;
            }
            this.$refs.kfFormRef.clearValidate('headImg');
            this.hideUpload = fileList.length >= this.limitCount;
        },
        // 处理图片预览效果
        codePreview(file) {
            this.codePath = file.url;
            this.codeVisible = true
        },
        codeRemove(file, fileList) {
            if(fileList.length==0){
                this.kfFormRules.codeImg = [{ required: true, message: '请上传微信二维码', trigger: 'change'}];
            }
            this.hideCode = fileList.length >= this.limitCode;
        },
        codeChange(file, fileList) {
            this.codeFile = file;
            this.codeFileList = fileList;
            if(fileList.length==1) {
                let {codeImg, ...data} = this.kfFormRules;
                this.kfFormRules = data;
            }
            this.$refs.kfFormRef.clearValidate('codeImg');
            this.hideCode = fileList.length >= this.limitCode;
        },
        certain() {
            console.log("dd",this.kfFormRules)
            this.$refs.kfFormRef.validate((valid) => {
            if (valid) {
                alert('submit!');
            } else {
                console.log('error submit!!');
                return false;
            }
            });
        },
        clearAll() {
            this.$refs.kfFormRef.resetFields();
            if(this.headFileList.length>0) {
                this.headFileList.splice(0,1)
                this.remove(this.headFile,this.headFileList);
            }
            if(this.codeFileList.length>0) {
                this.codeFileList.splice(0,1)
                this.codeRemove(this.codeFile,this.codeFileList)
            }
        },
       
    }, 
    mounted() {
        
    }
}
</script>

<style lang="less" scoped>
    .writeBox {
        display: flex;
        justify-content: space-between;
        flex-direction: row;
        flex-wrap: wrap;
        width: 100%;
        margin-bottom: 20px;
    }
    .el-row {
        width: 30%;
        margin-right: 10px;
        margin-bottom: 8px;
    }
    .el-col {
        white-space: nowrap;
    }
    .el-form-item {
        .el-input {
            width:400px;
            margin-right: 10px;
        }
    }
</style>

你可能感兴趣的:(vue.js,elementui,前端)