点击图片上传,清空验证结果,并且修改验证对象kfFormRules,移除里面关于头像上传的条件headImg,这些逻辑需要在on-change中去实现,然后在点击确定就不会有关于headImg的验证,具体可以看上图标出的控制台提示。
在点击删除图片时on-remove,需要把验证规则重新加回来
在重置按钮的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>