Newer
Older
KaiFengPC / src / components / DictTag / index.vue
@zhangdeliang zhangdeliang on 20 May 1 KB 项目初始化
<template>
  <div>
    <template v-for="(item, index) in options">
      <template v-if="values.includes(item.value)">
        <span v-if="item.elTagType == 'default' || item.elTagType == ''" :key="item.value" :index="index" :class="item.elTagClass">
          {{ item.label }}
        </span>
        <el-tag
          v-else
          :disable-transitions="true"
          :key="item.value + ''"
          :index="index"
          :type="item.elTagType === 'primary' ? '' : item.elTagType"
          :class="item.elTagClass"
        >
          {{ item.label }}
        </el-tag>
      </template>
    </template>
  </div>
</template>

<script setup>
const props = defineProps({
  // 数据
  options: {
    type: Array,
    default: null,
  },
  // 当前的值
  value: [Number, String, Array],
});

const values = computed(() => {
  if (props.value !== null && typeof props.value !== 'undefined') {
    return Array.isArray(props.value) ? props.value : [props.value];
  } else {
    return [];
  }
});
</script>

<style lang="scss" scoped>
@import '@/assets/styles/variables.module.scss';
.el-tag + .el-tag {
  margin-left: 10px;
}
:deep(.el-tag) {
  background-color: $mainColor2 !important;
  border-color: $mainColor2 !important;
  color: #fff;
}
</style>