From 1220f5ca98b10b735a47c37a81fbfc554b01e2fe Mon Sep 17 00:00:00 2001 From: liriming <1343021927@qq.com> Date: 星期一, 20 一月 2025 14:41:35 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- src/components/DictTag/src/DictTag.vue | 90 ++++++++++++++++++++++++++++++--------------- 1 files changed, 60 insertions(+), 30 deletions(-) diff --git a/src/components/DictTag/src/DictTag.vue b/src/components/DictTag/src/DictTag.vue index 1d075a1..6414eaa 100644 --- a/src/components/DictTag/src/DictTag.vue +++ b/src/components/DictTag/src/DictTag.vue @@ -1,8 +1,9 @@ <script lang="tsx"> -import { defineComponent, PropType, ref } from 'vue' +import { computed, defineComponent, PropType } from 'vue' import { isHexColor } from '@/utils/color' import { ElTag } from 'element-plus' import { DictDataType, getDictOptions } from '@/utils/dict' +import { isArray, isBoolean, isNumber, isString } from '@/utils/is' export default defineComponent({ name: 'DictTag', @@ -12,49 +13,78 @@ required: true }, value: { - type: [String, Number, Boolean] as PropType<string | number | boolean>, + type: [String, Number, Boolean, Array], required: true + }, + // 字符串分隔符 只有当 props.value 传入值为字符串时有效 + separator: { + type: String as PropType<string>, + default: ',' + }, + // 每个 tag 之间的间隔,默认为 5px,参考的 el-row 的 gutter + gutter: { + type: String as PropType<string>, + default: '5px' } }, setup(props) { - const dictData = ref<DictDataType>() - const getDictObj = (dictType: string, value: string) => { - const dictOptions = getDictOptions(dictType) - dictOptions.forEach((dict: DictDataType) => { - if (dict.value === value) { - if (dict.colorType + '' === 'default') { - dict.colorType = 'info' - } - dictData.value = dict - } - }) - } - const rederDictTag = () => { + const valueArr: any = computed(() => { + // 1. 是 Number 类型和 Boolean 类型的情况 + if (isNumber(props.value) || isBoolean(props.value)) { + return [String(props.value)] + } + // 2. 是字符串(进一步判断是否有包含分隔符号 -> props.sepSymbol ) + else if (isString(props.value)) { + return props.value.split(props.separator) + } + // 3. 数组 + else if (isArray(props.value)) { + return props.value.map(String) + } + return [] + }) + const renderDictTag = () => { if (!props.type) { return null } // 解决自定义字典标签值为零时标签不渲染的问题 - if (props.value === undefined || props.value === null) { + if (props.value === undefined || props.value === null || props.value === '') { return null } - getDictObj(props.type, props.value.toString()) - // 添加标签的文字颜色为白色,解决自定义背景颜色时标签文字看不清的问题 + const dictOptions = getDictOptions(props.type) + return ( - <ElTag - style={dictData.value?.cssClass ? 'color: #fff' : ''} - type={dictData.value?.colorType} - color={ - dictData.value?.cssClass && isHexColor(dictData.value?.cssClass) - ? dictData.value?.cssClass - : '' - } - disableTransitions={true} + <div + class="dict-tag" + style={{ + display: 'inline-flex', + gap: props.gutter, + justifyContent: 'center', + alignItems: 'center' + }} > - {dictData.value?.label} - </ElTag> + {dictOptions.map((dict: DictDataType) => { + if (valueArr.value.includes(dict.value)) { + if (dict.colorType + '' === 'primary' || dict.colorType + '' === 'default') { + dict.colorType = '' + } + return ( + // 添加标签的文字颜色为白色,解决自定义背景颜色时标签文字看不清的问题 + <ElTag + style={dict?.cssClass ? 'color: #fff' : ''} + type={dict?.colorType || null} + color={dict?.cssClass && isHexColor(dict?.cssClass) ? dict?.cssClass : ''} + disableTransitions={true} + > + {dict?.label} + </ElTag> + ) + } + })} + </div> ) } - return () => rederDictTag() + return () => renderDictTag() } }) </script> -- Gitblit v1.9.3