提交 48a49788 编写于 作者: yi.li's avatar yi.li

学科配置开发与联调

上级 e203b9fa
...@@ -37,6 +37,7 @@ ...@@ -37,6 +37,7 @@
</el-col> </el-col>
</el-row> </el-row>
<template v-for="(item, index) in formData.titleTestSubjectSecondModelList"> <template v-for="(item, index) in formData.titleTestSubjectSecondModelList">
<h4 style="margin-top:10px;font-weight: 600">{{ index+1 }}个二级分类:</h4>
<div class="list-block" :key="index"> <div class="list-block" :key="index">
<el-form-item <el-form-item
label="二级分类名称:" label="二级分类名称:"
...@@ -66,6 +67,14 @@ ...@@ -66,6 +67,14 @@
<span class="word-num">{{(item.code).replace(/\s+/g,"").length}}/8</span> <span class="word-num">{{(item.code).replace(/\s+/g,"").length}}/8</span>
</el-col> </el-col>
</el-form-item> </el-form-item>
<div class="checkbox-item">
<el-checkbox
v-model="item.checkedCourse"
@change="changeCourse(item.checkedCourse, index)"
style="margin-left: 15px;">配置课程</el-checkbox>
</div>
<div class="list-block-item" v-if="item.checkedCourse">
<p class="item-title">配置课程</p>
<el-form-item <el-form-item
label="是否已在项目配置课程:" label="是否已在项目配置课程:"
:prop="`titleTestSubjectSecondModelList.${index}.openFlag`" :prop="`titleTestSubjectSecondModelList.${index}.openFlag`"
...@@ -103,7 +112,160 @@ ...@@ -103,7 +112,160 @@
placeholder="选择月"> placeholder="选择月">
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
<i class="el-icon-delete icon-delete" @click="deleteCourseConfig(index)"></i>
</div>
<div class="checkbox-item">
<el-checkbox
v-model="item.checkedQue"
@change="changeQue(item.checkedQue, index)"
style="margin-left: 15px;"
>配置题库</el-checkbox>
</div>
<div class="list-block-item" v-if="item.checkedQue">
<p class="item-title">题库通用信息</p>
<el-row>
<el-col :span="11">
<el-form-item label="题库配图:">
<el-upload
v-model="item.directoryImageUrl"
class="bg-uploader"
action="#"
:show-file-list="false"
:before-upload="beforeUploadPic"
>
<img
v-if="item.directoryImageUrl"
@mouseover.stop="item.imgMouseOver=true"
:src="item.directoryImageUrl"
class="bg-img"
>
<img
v-if="!item.directoryImageUrl"
class="bg-img"
src="../../assets/image/small.png"
@click="getCurrentIndex(index)"
>
<div
class="img-delete"
v-show="item.imgMouseOver"
@click.stop="deleteImg(item.directoryImageUrl,index)"
@mouseout.stop="item.imgMouseOver=false">
<i class="el-icon-delete"></i>
</div>
<div class="limit-text">
<p>尺寸:686*160</p>
<p>限制大小: 500Kb</p>
<p>支持.jpg,.png格式</p>
</div>
</el-upload>
</el-form-item>
</el-col>
<el-col :span="13">
<el-form-item label="题库介绍:">
<el-input
size="small"
type="textarea"
:autosize="{ minRows: 5}"
placeholder="请输入入口简介"
v-model="item.directoryIntro"
maxlength="10"
style="width:83%;"
></el-input>
<span class="word-num">{{(item.directoryIntro).replace(/\s+/g,"").length}}/200</span>
</el-form-item>
</el-col>
</el-row>
<el-form-item
label="可解锁商品:"
:prop="`titleTestSubjectSecondModelList.${index}.nolockPro`"
:rules="{ required: true, message: '请选择可解锁商品', trigger: 'change'}"
>
<el-cascader
v-model="item.nolockPro"
:options="options"
:props="{ value: 'goodsType', label: 'goodsTypeName', children: 'cardsList'}"
size="small"></el-cascader>
</el-form-item>
<i class="el-icon-delete icon-delete" @click="deleteQC(index)"></i>
<el-row>
<el-col :span="13">
<el-button type="primary" icon="el-icon-plus" size="small" @click="addQuestionS(index)" :disabled="item.directoryList.length>=4">新增子题库</el-button>
</el-col>
</el-row>
<div v-for="(item2, index2) in item.directoryList" :key="index2">
<div class="list-block-item set-bg">
<p class="item-title">配置子题库</p>
<el-row>
<el-col :span="11">
<el-form-item
label="选择题库:"
:prop="`titleTestSubjectSecondModelList.${index}.directoryList.${index2}.resourceId`"
:rules="{ required: true, message: '请选择题库', trigger: 'change'}"
>
<el-select
v-model="item2.resourceId"
filterable
size="small"
clearable
placeholder="请选择题库"
:popper-append-to-body="false"
@change="changeQBValue(item2.resourceId,index2,index)"
>
<el-option
v-for="(directory, d) in secondDirectoryList"
:key="directory.id"
:label="directory.directoryName"
:value="directory.id">
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="13">
<el-form-item
label="前端题库名称:"
:prop="`titleTestSubjectSecondModelList.${index}.directoryList.${index2}.content1`"
:rules="{ required: true, message: '请输入前端题库名称', trigger: 'change'}"
>
<el-input
v-model="item2.content1"
type="text"
placeholder="默认取关联题库的名称,可修改"
size="small"
style="width: 80%"
maxlength="25">
</el-input>
<span class="word-num">{{(item2.content1).replace(/\s+/g,"").length}}/25</span>
</el-form-item>
</el-col>
</el-row>
<el-form-item
label="收费:"
:prop="`titleTestSubjectSecondModelList.${index}.directoryList.${index2}.freeFlag`"
:rules="{ required: true, message: '请选择收费项', trigger: 'change'}"
>
<el-radio-group v-model="item2.freeFlag">
<el-radio label="0">免费</el-radio>
<el-radio label="1">收费</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item
label="可免费体验题数:"
v-if="item2.freeFlag == 1"
:prop="`titleTestSubjectSecondModelList.${index}.directoryList.${index2}.content2`"
:rules="freeContentRules"
>
<el-input
type="number"
v-model="item2.content2"
placeholder="请输入自然数"
style="width: 200px;">
<template slot="append"></template>
</el-input>
</el-form-item>
<i v-show="index2 !== 0" class="el-icon-delete icon-delete" @click="deleteSecondQB(item2,index2,index)"></i>
</div>
</div>
</div>
<i v-show="index !== 0" class="el-icon-delete icon-delete" @click="deleteSecondList(index)"></i> <i v-show="index !== 0" class="el-icon-delete icon-delete" @click="deleteSecondList(index)"></i>
</div> </div>
</template> </template>
...@@ -121,6 +283,8 @@ ...@@ -121,6 +283,8 @@
import BreadCrumb from "@/components/breadcrumb.vue"; import BreadCrumb from "@/components/breadcrumb.vue";
import { openLoading, closeLoading, deepCopy } from "@/utils/utils"; import { openLoading, closeLoading, deepCopy } from "@/utils/utils";
import * as commonUtil from "@/utils/utils"; import * as commonUtil from "@/utils/utils";
import {doUpload, getFilePath} from "../../utils/qiniu-util";
import { checkIsInteger } from '@/utils/followup/followupUtils/checkField';
let checkProjectStr = (rule, value, callback) => { let checkProjectStr = (rule, value, callback) => {
if (value.indexOf("\\") != -1) { if (value.indexOf("\\") != -1) {
...@@ -162,19 +326,43 @@ export default { ...@@ -162,19 +326,43 @@ export default {
seqNo: 1, seqNo: 1,
subjectFirstId: '', subjectFirstId: '',
projectId: '', projectId: '',
checkedCourse: false,//新增字段-配置课程
checkedQue: false,//新增字段-配置题库
directoryImageUrl: '',//新增字段-题库配图
directoryIntro: '',//新增字段-题库介绍
nolockPro: [],//新增字段-可解锁商品
goodsType: null,//新增字段-商品类型
cardType: null,//新增字段-卡类型
imgMouseOver: false,//新增字段
titleTestSubjectSecondResourceModelList: [{ titleTestSubjectSecondResourceModelList: [{
// deleteFlag: 0, // deleteFlag: 0,
id: 0, id: 0,
resourceId: 0, resourceId: 0,
seqNo: 1, seqNo: 1,
subjectSecondId: 0, subjectSecondId: 0,
type: 0 type: 1
}] }],
directoryList: [
{
type: 2,//关联资源类型,1项目,2题库
subjectSecondId: 0,//二级分类id
seqNo: 1,
resourceId: null,//关联资源id
id: 0,
freeFlag: 1,//题库是否免费:0免费1收费
content1: '',//题库分类名称
content2: '',//表示免费体检题数
}
],
} }
], ],
}, },
gradeList: [], // 职称列表 gradeList: [], // 职称列表
projectList: [], // 项目列表 projectList: [], // 项目列表
copyLockList: [],
options: [],
secondDirectoryList: [],//题库列表
activeIndexImg: null,
rules: { rules: {
titleCode: [ titleCode: [
{ required: true, message: "请输入选择职称", trigger: "change" }, { required: true, message: "请输入选择职称", trigger: "change" },
...@@ -190,6 +378,10 @@ export default { ...@@ -190,6 +378,10 @@ export default {
{ min: 1, max: 20, message: "输入长度为1-20的二级分类名称", trigger: "blur" }, { min: 1, max: 20, message: "输入长度为1-20的二级分类名称", trigger: "blur" },
{ validator: checkProjectStr, trigger: "blur" } { validator: checkProjectStr, trigger: "blur" }
], ],
freeContentRules: [
{ required: true, message: '请输入免费体验题数', trigger: ['blur','change']},
{ validator: checkIsInteger, trigger: ['blur','change'] }
],
// secondCodeRules: [ // secondCodeRules: [
// // { required: true, message: "请输入二级分类代码", trigger: "blur" }, // // { required: true, message: "请输入二级分类代码", trigger: "blur" },
// // { min: 1, max: 8, message: "输入长度为1-8的二级分类代码", trigger: "blur" }, // // { min: 1, max: 8, message: "输入长度为1-8的二级分类代码", trigger: "blur" },
...@@ -203,6 +395,8 @@ export default { ...@@ -203,6 +395,8 @@ export default {
} }
this.getGradeList(); this.getGradeList();
this.getProjectList(); this.getProjectList();
this.getGoodsTypeList();
this.getsecondDirectoryList();
}, },
mounted() { mounted() {
commonUtil.resizeHeight(); commonUtil.resizeHeight();
...@@ -241,9 +435,41 @@ export default { ...@@ -241,9 +435,41 @@ export default {
} }
}); });
}, },
//获取商品分类
getGoodsTypeList() {
openLoading(this);
this.GET("trade/goods/manager/queryGoodsType").then(res => {
closeLoading(this);
if (res.code == "000000") {
this.copyLockList = deepCopy(res.data);
let data = res.data;
this.options = this.getProSelect(data);
}
});
},
getProSelect(data) {
for (let i = 0; i < data.length; i++) {
data[i].cardsList.map(item => {
this.$set(item, "goodsType", item.cardType);
this.$set(item, "goodsTypeName", item.cardTypeName);
this.$set(item, "leaf", true);
});
}
return data;
},
//获取题库列表
getsecondDirectoryList() {
openLoading(this);
this.GET(`onlineexam/brushExamTitleDirectory?directoryType=1`).then(res => {
closeLoading(this);
if (res.code == "000000") {
this.secondDirectoryList = res.data;
}
});
},
// 添加二级分类 // 添加二级分类
addSecondList() { addSecondList() {
this.formData.titleTestSubjectSecondModelList.push({ let item = {
code: '', code: '',
// deleteFlag: 0, // deleteFlag: 0,
id: 0, id: 0,
...@@ -253,15 +479,36 @@ export default { ...@@ -253,15 +479,36 @@ export default {
seqNo: 1, seqNo: 1,
subjectFirstId: '', subjectFirstId: '',
projectId: '', projectId: '',
checkedCourse: false,//新增字段-配置课程
checkedQue: false,//新增字段-配置题库
directoryImageUrl: '',//新增字段-题库配图
directoryIntro: '',//新增字段-题库介绍
nolockPro: [],//新增字段-可解锁商品
goodsType: null,//新增字段-商品类型
cardType: null,//新增字段-卡类型
imgMouseOver: false,//新增字段
titleTestSubjectSecondResourceModelList: [{ titleTestSubjectSecondResourceModelList: [{
// deleteFlag: 0, // deleteFlag: 0,
id: 0, id: 0,
resourceId: 0, resourceId: 0,
seqNo: 1, seqNo: 1,
subjectSecondId: 0, subjectSecondId: 0,
type: 0 type: 1
}] }],
}); directoryList: [
{
type: 2,//关联资源类型,1项目,2题库
subjectSecondId: 0,//二级分类id
seqNo: 1,
resourceId: null,//关联资源id
id: 0,
freeFlag: 1,//题库是否免费:0免费1收费
content1: '',//题库分类名称
content2: '',//表示免费体检题数
}
],
}
this.formData.titleTestSubjectSecondModelList.push(item);
}, },
// 删除二级分类 // 删除二级分类
deleteSecondList(index) { deleteSecondList(index) {
...@@ -274,16 +521,52 @@ export default { ...@@ -274,16 +521,52 @@ export default {
}).catch(() => { }).catch(() => {
}); });
}, },
//提交
onSubmit() { onSubmit() {
this.$refs['formData'].validate((valid) => { this.$refs['formData'].validate((valid) => {
if (!valid) { if (!valid) {
return false; return false;
} }
const params = deepCopy(this.formData); const params = deepCopy(this.formData);
// for (let item of params.titleTestSubjectSecondModelList) {
let item = {}; let item = {};
for (let i = 0; i < params.titleTestSubjectSecondModelList.length; i ++) { for (let i = 0; i < params.titleTestSubjectSecondModelList.length; i ++) {
item = params.titleTestSubjectSecondModelList[i]; item = params.titleTestSubjectSecondModelList[i];
//新增处理-配置课程
if (!item.checkedCourse) {
item.openFlag = null;
item.projectId = '';
item.predictTime = '';
}
//新增处理-配置题库
if (!item.checkedQue) {
item.directoryImageUrl = '';
item.directoryIntro = '';
item.nolockPro = [];
item.goodsType = null;
item.cardType = null;
item.directoryList = [
{
type: 2,//关联资源类型,1项目,2题库
subjectSecondId: 0,//二级分类id
seqNo: 1,
resourceId: null,//关联资源id
id: 0,
freeFlag: 1,//题库是否免费:0免费1收费
content1: '',//题库分类名称
content2: '',//表示免费体检题数
}
];
}else {
item.goodsType = item.nolockPro[0];
item.cardType = item.nolockPro[1];
for (let item2 of item.directoryList) {
if (item2.freeFlag == 0) {
item2.content2 = '';
}
}
}
let id = item.projectId; let id = item.projectId;
item.titleTestSubjectSecondResourceModelList[0]['resourceId'] = id || 0; item.titleTestSubjectSecondResourceModelList[0]['resourceId'] = id || 0;
// 添加或重置排序字段 // 添加或重置排序字段
...@@ -291,8 +574,6 @@ export default { ...@@ -291,8 +574,6 @@ export default {
delete item.projectId; delete item.projectId;
} }
// params.createdName = this.$store.state.reservationManage.userName; // params.createdName = this.$store.state.reservationManage.userName;
openLoading(this); openLoading(this);
this.POST("portal/titleTest/insertOrUpdate", params).then(res => { this.POST("portal/titleTest/insertOrUpdate", params).then(res => {
...@@ -316,7 +597,7 @@ export default { ...@@ -316,7 +597,7 @@ export default {
const modelList = []; const modelList = [];
for (let item of result.secondSubjectModelList) { for (let item of result.secondSubjectModelList) {
if (item.resourceModelList && item.resourceModelList[0]) { if (item.resourceModelList && item.resourceModelList[0]) {
item.projectId = item.resourceModelList[0]['resourceId'] item.projectId = item.resourceModelList[0]['resourceId'];
item.titleTestSubjectSecondResourceModelList = item.resourceModelList; item.titleTestSubjectSecondResourceModelList = item.resourceModelList;
delete item.resourceModelList; delete item.resourceModelList;
} else { } else {
...@@ -327,9 +608,22 @@ export default { ...@@ -327,9 +608,22 @@ export default {
resourceId: 0, resourceId: 0,
seqNo: 1, seqNo: 1,
subjectSecondId: 0, subjectSecondId: 0,
type: 0 type: 1
}] }]
} }
//新增处理逻辑
item.checkedCourse = false;
item.checkedQue = false;
item.nolockPro = [];
if (item.projectId || item.predictTime) {
item.checkedCourse = true;
}
if (item.goodsType && item.cardType) {
item.nolockPro = [Number(item.goodsType),Number(item.cardType)];
item.checkedQue = true;
}
item.imgMouseOver = false;
modelList.push(item); modelList.push(item);
} }
result.titleTestSubjectSecondModelList = modelList; result.titleTestSubjectSecondModelList = modelList;
...@@ -354,19 +648,189 @@ export default { ...@@ -354,19 +648,189 @@ export default {
seqNo: 1, seqNo: 1,
subjectFirstId: '', subjectFirstId: '',
projectId: '', projectId: '',
checkedCourse: false,//新增字段-配置课程
checkedQue: false,//新增字段-配置题库
directoryImageUrl: '',//新增字段-题库配图
directoryIntro: '',//新增字段-题库介绍
nolockPro: [],//新增字段-可解锁商品
goodsType: null,//新增字段-商品类型
cardType: null,//新增字段-卡类型
imgMouseOver: false,//新增字段
titleTestSubjectSecondResourceModelList: [{ titleTestSubjectSecondResourceModelList: [{
// deleteFlag: 0, // deleteFlag: 0,
id: 0, id: 0,
resourceId: 0, resourceId: 0,
seqNo: 1, seqNo: 1,
subjectSecondId: 0, subjectSecondId: 0,
type: 0 type: 1
}] }],
directoryList: [
{
type: 2,//关联资源类型,1项目,2题库
subjectSecondId: 0,//二级分类id
seqNo: 1,
resourceId: null,//关联资源id
id: 0,
freeFlag: 1,//题库是否免费:0免费1收费
content1: '',//题库分类名称
content2: '',//表示免费体检题数
} }
], ],
} }
],
}
}
},
changeCourse(value, indexL0) {
if (!value) {
this.deleteCourseConfig(indexL0);
}
},
changeQue(value, indexL0) {
if (!value) {
this.deleteQC(indexL0);
}
},
//课程配置的删除操作
deleteCourseConfig(indexL0) {
this.$confirm('确定删除当前二级分类的课程配置吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
this.formData.titleTestSubjectSecondModelList[indexL0].checkedCourse = false;
// this.formData.titleTestSubjectSecondModelList.splice(indexL0, 1);
}).catch(() => {
this.formData.titleTestSubjectSecondModelList[indexL0].checkedCourse = true;
});
},
//题库配置的删除操作
deleteQC(indexL0) {
this.$confirm('确定删除当前二级分类的题库配置吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
this.formData.titleTestSubjectSecondModelList[indexL0].checkedQue = false;
}).catch(() => {
this.formData.titleTestSubjectSecondModelList[indexL0].checkedQue = true;
});
},
getCurrentIndex(indexL0) {
this.activeIndexImg = indexL0;
},
beforeUploadPic(file) {
let fileLimit = {
width: 686,
height: 160,
size: 0.5,
sizeText: "500Kb",
key: "directoryImageUrl",
more: "directoryImageUrl",
show: "uploadImgMessage1"
};
this.beforeAvatarUpload(file, fileLimit);
},
//上传图片校验
beforeAvatarUpload(file, fileLimit) {
let vm = this;
const isJPG = file.type === "image/jpeg";
const isPNG = file.type === "image/png";
const isLt2M = file.size / 1024 / 1024 < fileLimit.size;
if (!isJPG && !isPNG) {
this.$message.error("图片不符合规范,请根据规范上传图片");
// return;
}
if (!isLt2M) {
this.$message.error("图片不符合规范,请根据规范上传图片 ");
// return;
} }
let _img = new FileReader();
_img.readAsDataURL(file);
_img.onload = function(theFile) {
let image = new Image();
image.src = theFile.target.result;
image.onload = function() {
let _this = this;
if (
false
// _this.width != fileLimit.width ||
// _this.height != fileLimit.height
) {
vm.$message.error("图片不符合规范,请根据规范上传图片");
} else {
openLoading(vm);
doUpload(
vm,
file,
getFilePath(file, null),
"preview4",
"progress1",
1
).then(function(path) {
closeLoading(vm);
console.log(path);
vm.formData.titleTestSubjectSecondModelList[vm.activeIndexImg][fileLimit.key] = path.fullPath;
// vm.formData[fileLimit.more] = {
// attachmentName: path.name,
// attachmentExt: path.ext,
// attachmentSize: path.size
// };
vm.$message.success("上传成功");
});
} }
};
};
return isJPG && isLt2M;
},
//删除图片
deleteImg(img, indexL0) {
this.formData.titleTestSubjectSecondModelList[indexL0].directoryImageUrl = '';
this.formData.titleTestSubjectSecondModelList[indexL0].imgMouseOver = false;
},
//新增子题库
addQuestionS(activeIndex) {
let seqLength = this.formData.titleTestSubjectSecondModelList[activeIndex].directoryList.length;
let obj = {
type: 2,//关联资源类型,1项目,2题库
subjectSecondId: 0,//二级分类id
seqNo: seqLength+1,
resourceId: null,//关联资源id
id: 0,
freeFlag: 1,//题库是否免费:0免费,1收费
content1: '',//题库分类名称
content2: '',//表示免费体检题数
}
if (seqLength >=4) {
this.$message.warning('最多只能增加4个子题库')
return;
}
this.formData.titleTestSubjectSecondModelList[activeIndex].directoryList.push(obj)
},
formatDirectory(value) {
let directoryName = '';
for (let i=0; i<this.secondDirectoryList.length; i++) {
if (this.secondDirectoryList[i].id == value) {
directoryName = this.secondDirectoryList[i].directoryName;
}
}
return directoryName;
},
changeQBValue(value,indexL1,indexL0) {
let directoryName = this.formatDirectory(value);
this.formData.titleTestSubjectSecondModelList[indexL0].directoryList[indexL1].content1 = directoryName;
},
//删除子题库
deleteSecondQB(obj1,indexL1, indexL0) {
this.$confirm('确定删除此子题库吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
this.formData.titleTestSubjectSecondModelList[indexL0].directoryList.splice(indexL1, 1);
}).catch(() => {
});
},
}, },
} }
</script> </script>
...@@ -383,10 +847,36 @@ export default { ...@@ -383,10 +847,36 @@ export default {
} }
.list-block{ .list-block{
position: relative; position: relative;
padding: 20px 10px 0px; padding: 20px 10px 10px;
border: 1px solid #cdcdcd; border: 1px solid #cdcdcd;
border-radius: 5px; border-radius: 5px;
margin-top: 25px; margin-top: 25px;
margin-bottom: 20px;
}
.checkbox-item{
margin-bottom: 22px;
}
.list-block-item{
position: relative;
padding: 10px;
border: 1px solid #cdcdcd;
border-radius: 5px;
margin-top: 15px;
margin-bottom: 15px;
.icon-delete{
position: absolute;
right: 20px;
top: 10px;
font-size: 30px;
color: red;
cursor: pointer;
}
.item-title{
margin: 5px 0 15px;
}
&.set-bg{
background-color: #f1f1f1;
}
} }
.icon-delete{ .icon-delete{
position: absolute; position: absolute;
...@@ -396,4 +886,57 @@ export default { ...@@ -396,4 +886,57 @@ export default {
color: red; color: red;
cursor: pointer; cursor: pointer;
} }
.bg-uploader {
img {
float: left;
}
.bg-img {
width: 84px;
height: 100px;
}
.bg-video {
float: left;
width: 84px;
height: 100px;
}
.img-delete {
position: absolute;
left: 0px;
top: 0px;
width: 84px;
height: 100px;
background: #000;
opacity: 0.7;
z-index: 999;
i {
color: #fff;
margin-top: 39px;
margin-left: 0px;
}
}
.limit-text {
float: left;
margin-left: 10px;
margin-top: -10px;
p {
font-size: 12px;
color: #999;
}
}
}
</style>
<style>
.el-checkbox__input.is-checked+.el-checkbox__label{
color: #449284;
}
.el-checkbox__input.is-checked .el-checkbox__inner,
.el-checkbox__input.is-indeterminate .el-checkbox__inner{
background-color: #449284;
border-color: #449284;
}
.required-label .el-form-item__label::before {
content: "*";
color: #f56c6c;
margin-right: 4px;
}
</style> </style>
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册