mirror of
https://github.com/soybeanjs/soybean-admin.git
synced 2025-09-20 02:26:39 +08:00
52 lines
1.9 KiB
Vue
52 lines
1.9 KiB
Vue
<script lang="ts" setup>
|
||
import { ref } from 'vue';
|
||
import { icons } from './icons';
|
||
|
||
const selectValue = ref('');
|
||
|
||
const localIcons = ['custom-icon', 'activity', 'at-sign', 'cast', 'chrome', 'copy', 'wind'];
|
||
</script>
|
||
|
||
<template>
|
||
<div class="h-full">
|
||
<NCard title="Icon组件示例" :bordered="false" class="card-wrapper">
|
||
<div class="grid grid-cols-10">
|
||
<template v-for="item in icons" :key="item">
|
||
<div class="mt-5px flex-x-center">
|
||
<SvgIcon :icon="item" class="text-30px" />
|
||
</div>
|
||
</template>
|
||
</div>
|
||
<div class="mt-50px">
|
||
<h1 class="mb-20px text-18px font-500">Icon图标选择器</h1>
|
||
<CustomIconSelect v-model:value="selectValue" :icons="icons" />
|
||
</div>
|
||
<template #footer>
|
||
<WebSiteLink label="iconify地址:" link="https://icones.js.org/" class="mt-10px" />
|
||
</template>
|
||
</NCard>
|
||
<NCard title="自定义图标示例" :bordered="false" class="mt-10px card-wrapper">
|
||
<div class="pb-12px text-16px">
|
||
在src/assets/svg-icon文件夹下的svg文件,通过在template里面以 icon-local-{文件名} 直接渲染,
|
||
其中icon-local为.env文件里的 VITE_ICON_LOCAL_PREFIX
|
||
</div>
|
||
<div class="grid grid-cols-10">
|
||
<div class="mt-5px flex-x-center">
|
||
<icon-local-activity class="text-40px text-success" />
|
||
</div>
|
||
<div class="mt-5px flex-x-center">
|
||
<icon-local-cast class="text-20px text-error" />
|
||
</div>
|
||
</div>
|
||
<div class="py-12px text-16px">通过SvgIcon组件动态渲染, 菜单通过meta的localIcon属性渲染自定义图标</div>
|
||
<div class="grid grid-cols-10">
|
||
<div v-for="(fileName, index) in localIcons" :key="index" class="mt-5px flex-x-center">
|
||
<SvgIcon :local-icon="fileName" class="text-30px text-primary" />
|
||
</div>
|
||
</div>
|
||
</NCard>
|
||
</div>
|
||
</template>
|
||
|
||
<style scoped></style>
|