12345678910111213141516171819202122232425262728293031323334353637 |
- <script setup lang="ts">
- const props = withDefaults(defineProps<{ size?: 'large' | '110x44'; color?: 'black' }>(), {
- size: 'large',
- color: 'black',
- })
- const width = computed(() => Number(props.size.split('x')[0]) * 2 + 'rpx')
- const height = computed(() => Number(props.size.split('x')[1]) * 2 + 'rpx')
- const types = [
- {
- color: 'black',
- size: '110x44',
- src: '',
- },
- {
- size: 'large',
- color: 'black',
- width: 110,
- height: 44,
- src: '',
- },
- ]
- const type = computed(() =>
- types.find(({ size, color }) => props.size === size && props.color === color),
- )
- </script>
- <template>
- <div
- class="flex items-center justify-center bg-[length:100%_100%] text-white pl-4 pr-2 box-border text-white text-base font-normal font-['PingFang_SC'] leading-tight"
- :style="{
- width: type.width * 2 + 'rpx',
- height: type.height * 2 + 'rpx',
- backgroundImage: `url(${type.src})`,
- }"
- >
- <slot></slot>
- </div>
- </template>
|