index.vue 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <template>
  2. <div>
  3. <template v-for="(item, index) in options">
  4. <template v-if="values.includes(item.value)">
  5. <span
  6. v-if="item.elTagType == 'default' || item.elTagType == ''"
  7. :key="item.value"
  8. :index="index"
  9. :class="item.elTagClass"
  10. >{{ item.label }}</span>
  11. <el-tag
  12. v-else
  13. :disable-transitions="true"
  14. :key="item.value + ''"
  15. :index="index"
  16. :type="item.elTagType === 'primary' ? '' : item.elTagType"
  17. :class="item.elTagClass"
  18. >{{ item.label }}</el-tag>
  19. </template>
  20. </template>
  21. </div>
  22. </template>
  23. <script setup>
  24. const props = defineProps({
  25. // 数据
  26. options: {
  27. type: Array,
  28. default: null,
  29. },
  30. // 当前的值
  31. value: [Number, String, Array],
  32. })
  33. const values = computed(() => {
  34. if (props.value !== null && typeof props.value !== 'undefined') {
  35. return Array.isArray(props.value) ? props.value : [String(props.value)];
  36. } else {
  37. return [];
  38. }
  39. })
  40. </script>
  41. <style scoped>
  42. .el-tag + .el-tag {
  43. margin-left: 10px;
  44. }
  45. </style>