<template> <el-checkbox v-model="model" :style="{'border-bottom': isShowRed ? `1px solid ${isShowRed}` : ''}" v-bind="$attrs" v-on="$listeners" :disabled="isDisable" @change="handleChange" > <slot></slot> </el-checkbox> </template> <script> import commonDepend from '~/mixin/commonDepend.js' import markSetShowRed from '~/components/business/componentMixins/markSetShowRed.js' export default { inject: { root: { default: () => null } }, mixins: [commonDepend, markSetShowRed], props: { value: { type: String | Boolean, default: '' }, disabled: { type: Boolean, default: false }, // 此对象为markset或者modifySet所在的对象,如果传了此对象可以标记当前对象下的字段为红色下划线 markSetData: { type: Object, default: () => null }, customModifykey: { type: String, default: null } }, computed: { model: { get () { return this.value }, set (newVal) { this.$emit('input', newVal) } }, mode () { return this.$store.state.Status.mode }, isDisable() { return this.mode === 'display' || this.disabled }, }, watch: { disabled(newVal) { if (newVal) { this.resetValidate() } } }, methods: { handleChange () { if (!this.customModifykey) { // 添加isModify属性 this.changeModify() } }, } } </script>