1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Ant Design of Vue图标选择器

Ant Design of Vue图标选择器

时间:2021-07-28 01:54:21

相关推荐

Ant Design of Vue图标选择器

看了一下antDesign并没有图标选择的组件,在网上查找了一下资料发现这篇文章已经实现了下拉选择图标的需求;

antd vue图标选择器/a2925447584/article/details/116702831

但是实底图标,线性图标,双色图标全部混在了一起,功能虽然已经实现了,但后期用户查找起来比较麻烦,于是打算自己手动写一个图标选择器,实现效果如下:

可对图标风格进行切换

一、全局图标

main.js中引入全部图标

import { createApp } from 'vue';import App from './App.vue';import Antd from 'ant-design-vue';import 'ant-design-vue/dist/antd.css';import * as antIcons from "@ant-design/icons-vue";import RouterIndex from './router/index';import axios from 'axios';import VueAxios from 'vue-axios';const app = createApp(App).use(Antd);app.use(RouterIndex);// 注册组件Object.keys(antIcons).forEach(key => {ponent(key, antIcons[key])})// 添加到全局app.config.globalProperties.$antIcons = antIconsapp.mount("#app");

二、图标选择器组件

iconPicker组件

<template><a-radio-group v-model:value="value1" button-style="solid"><a-radio-button value="1">线框风格</a-radio-button><a-radio-button value="2">实底风格</a-radio-button><a-radio-button value="3">双色风格</a-radio-button></a-radio-group><div style="margin-top: 15px;"><span v-for="(item,i) in iconList" class="icons-list"><span v-if="value1==1"><component class="icon" @click="sendMsg(iconList[i])" v-if="iconList[i].indexOf('Outlined')>0" :is="$antIcons[iconList[i]]" /></span><span v-if="value1==2"><component class="icon" @click="sendMsg(iconList[i])" v-if="iconList[i].indexOf('Filled')>0" :is="$antIcons[iconList[i]]" /></span><span v-if="value1==3"><component class="icon" @click="sendMsg(iconList[i])" v-if="iconList[i].indexOf('TwoTone')>0" :is="$antIcons[iconList[i]]" /></span></span></div></template><script>import {defineComponent} from 'vue';import {HomeOutlined,SettingFilled,SmileOutlined,SyncOutlined,LoadingOutlined,} from '@ant-design/icons-vue';import iconList from '../iconPicker/icons.json'export default defineComponent({components: {HomeOutlined,SettingFilled,SmileOutlined,SyncOutlined,LoadingOutlined,},data() {return {iconList: iconList,value1: "1",}},methods:{sendMsg:function(iconText) {//func: 是父组件指定的传数据绑定的函数,this.msg:子组件给父组件传递的数据this.$emit('func', iconText)}},created() {}});</script><style scoped>.icons-list :deep(.anticon) {margin-right: 6px;font-size: 24px;}.icon:hover {background-color: #1890ff;color: white;}</style>

需引入的icons.json文件

["AccountBookFilled","AccountBookOutlined","AccountBookTwoTone","AimOutlined","AlertFilled","AlertOutlined","AlertTwoTone","AlibabaOutlined","AlignCenterOutlined","AlignLeftOutlined","AlignRightOutlined","AlipayCircleFilled","AlipayCircleOutlined","AlipayOutlined","AlipaySquareFilled","AliwangwangFilled","AliwangwangOutlined","AliyunOutlined","AmazonCircleFilled","AmazonOutlined","AmazonSquareFilled","AndroidFilled","AndroidOutlined","AntCloudOutlined","AntDesignOutlined","ApartmentOutlined","ApiFilled","ApiOutlined","ApiTwoTone","AppleFilled","AppleOutlined","AppstoreAddOutlined","AppstoreFilled","AppstoreOutlined","AppstoreTwoTone","AreaChartOutlined","ArrowDownOutlined","ArrowLeftOutlined","ArrowRightOutlined","ArrowUpOutlined","ArrowsAltOutlined","AudioFilled","AudioMutedOutlined","AudioOutlined","AudioTwoTone","AuditOutlined","BackwardFilled","BackwardOutlined","BankFilled","BankOutlined","BankTwoTone","BarChartOutlined","BarcodeOutlined","BarsOutlined","BehanceCircleFilled","BehanceOutlined","BehanceSquareFilled","BehanceSquareOutlined","BellFilled","BellOutlined","BellTwoTone","BgColorsOutlined","BlockOutlined","BoldOutlined","BookFilled","BookOutlined","BookTwoTone","BorderBottomOutlined","BorderHorizontalOutlined","BorderInnerOutlined","BorderLeftOutlined","BorderOuterOutlined","BorderOutlined","BorderRightOutlined","BorderTopOutlined","BorderVerticleOutlined","BorderlessTableOutlined","BoxPlotFilled","BoxPlotOutlined","BoxPlotTwoTone","BranchesOutlined","BugFilled","BugOutlined","BugTwoTone","BuildFilled","BuildOutlined","BuildTwoTone","BulbFilled","BulbOutlined","BulbTwoTone","CalculatorFilled","CalculatorOutlined","CalculatorTwoTone","CalendarFilled","CalendarOutlined","CalendarTwoTone","CameraFilled","CameraOutlined","CameraTwoTone","CarFilled","CarOutlined","CarTwoTone","CaretDownFilled","CaretDownOutlined","CaretLeftFilled","CaretLeftOutlined","CaretRightFilled","CaretRightOutlined","CaretUpFilled","CaretUpOutlined","CarryOutFilled","CarryOutOutlined","CarryOutTwoTone","CheckCircleFilled","CheckCircleOutlined","CheckCircleTwoTone","CheckOutlined","CheckSquareFilled","CheckSquareOutlined","CheckSquareTwoTone","ChromeFilled","ChromeOutlined","CiCircleFilled","CiCircleOutlined","CiCircleTwoTone","CiOutlined","CiTwoTone","ClearOutlined","ClockCircleFilled","ClockCircleOutlined","ClockCircleTwoTone","CloseCircleFilled","CloseCircleOutlined","CloseCircleTwoTone","CloseOutlined","CloseSquareFilled","CloseSquareOutlined","CloseSquareTwoTone","CloudDownloadOutlined","CloudFilled","CloudOutlined","CloudServerOutlined","CloudSyncOutlined","CloudTwoTone","CloudUploadOutlined","ClusterOutlined","CodeFilled","CodeOutlined","CodeSandboxCircleFilled","CodeSandboxOutlined","CodeSandboxSquareFilled","CodeTwoTone","CodepenCircleFilled","CodepenCircleOutlined","CodepenOutlined","CodepenSquareFilled","CoffeeOutlined","ColumnHeightOutlined","ColumnWidthOutlined","CommentOutlined","CompassFilled","CompassOutlined","CompassTwoTone","CompressOutlined","ConsoleSqlOutlined","ContactsFilled","ContactsOutlined","ContactsTwoTone","ContainerFilled","ContainerOutlined","ContainerTwoTone","ControlFilled","ControlOutlined","ControlTwoTone","CopyFilled","CopyOutlined","CopyTwoTone","CopyrightCircleFilled","CopyrightCircleOutlined","CopyrightCircleTwoTone","CopyrightOutlined","CopyrightTwoTone","CreditCardFilled","CreditCardOutlined","CreditCardTwoTone","CrownFilled","CrownOutlined","CrownTwoTone","CustomerServiceFilled","CustomerServiceOutlined","CustomerServiceTwoTone","DashOutlined","DashboardFilled","DashboardOutlined","DashboardTwoTone","DatabaseFilled","DatabaseOutlined","DatabaseTwoTone","DeleteColumnOutlined","DeleteFilled","DeleteOutlined","DeleteRowOutlined","DeleteTwoTone","DeliveredProcedureOutlined","DeploymentUnitOutlined","DesktopOutlined","DiffFilled","DiffOutlined","DiffTwoTone","DingdingOutlined","DingtalkCircleFilled","DingtalkOutlined","DingtalkSquareFilled","DisconnectOutlined","DislikeFilled","DislikeOutlined","DislikeTwoTone","DollarCircleFilled","DollarCircleOutlined","DollarCircleTwoTone","DollarOutlined","DollarTwoTone","DotChartOutlined","DoubleLeftOutlined","DoubleRightOutlined","DownCircleFilled","DownCircleOutlined","DownCircleTwoTone","DownOutlined","DownSquareFilled","DownSquareOutlined","DownSquareTwoTone","DownloadOutlined","DragOutlined","DribbbleCircleFilled","DribbbleOutlined","DribbbleSquareFilled","DribbbleSquareOutlined","DropboxCircleFilled","DropboxOutlined","DropboxSquareFilled","EditFilled","EditOutlined","EditTwoTone","EllipsisOutlined","EnterOutlined","EnvironmentFilled","EnvironmentOutlined","EnvironmentTwoTone","EuroCircleFilled","EuroCircleOutlined","EuroCircleTwoTone","EuroOutlined","EuroTwoTone","ExceptionOutlined","ExclamationCircleFilled","ExclamationCircleOutlined","ExclamationCircleTwoTone","ExclamationOutlined","ExpandAltOutlined","ExpandOutlined","ExperimentFilled","ExperimentOutlined","ExperimentTwoTone","ExportOutlined","EyeFilled","EyeInvisibleFilled","EyeInvisibleOutlined","EyeInvisibleTwoTone","EyeOutlined","EyeTwoTone","FacebookFilled","FacebookOutlined","FallOutlined","FastBackwardFilled","FastBackwardOutlined","FastForwardFilled","FastForwardOutlined","FieldBinaryOutlined","FieldNumberOutlined","FieldStringOutlined","FieldTimeOutlined","FileAddFilled","FileAddOutlined","FileAddTwoTone","FileDoneOutlined","FileExcelFilled","FileExcelOutlined","FileExcelTwoTone","FileExclamationFilled","FileExclamationOutlined","FileExclamationTwoTone","FileFilled","FileGifOutlined","FileImageFilled","FileImageOutlined","FileImageTwoTone","FileJpgOutlined","FileMarkdownFilled","FileMarkdownOutlined","FileMarkdownTwoTone","FileOutlined","FilePdfFilled","FilePdfOutlined","FilePdfTwoTone","FilePptFilled","FilePptOutlined","FilePptTwoTone","FileProtectOutlined","FileSearchOutlined","FileSyncOutlined","FileTextFilled","FileTextOutlined","FileTextTwoTone","FileTwoTone","FileUnknownFilled","FileUnknownOutlined","FileUnknownTwoTone","FileWordFilled","FileWordOutlined","FileWordTwoTone","FileZipFilled","FileZipOutlined","FileZipTwoTone","FilterFilled","FilterOutlined","FilterTwoTone","FireFilled","FireOutlined","FireTwoTone","FlagFilled","FlagOutlined","FlagTwoTone","FolderAddFilled","FolderAddOutlined","FolderAddTwoTone","FolderFilled","FolderOpenFilled","FolderOpenOutlined","FolderOpenTwoTone","FolderOutlined","FolderTwoTone","FolderViewOutlined","FontColorsOutlined","FontSizeOutlined","ForkOutlined","FormOutlined","FormatPainterFilled","FormatPainterOutlined","ForwardFilled","ForwardOutlined","FrownFilled","FrownOutlined","FrownTwoTone","FullscreenExitOutlined","FullscreenOutlined","FunctionOutlined","FundFilled","FundOutlined","FundProjectionScreenOutlined","FundTwoTone","FundViewOutlined","FunnelPlotFilled","FunnelPlotOutlined","FunnelPlotTwoTone","GatewayOutlined","GifOutlined","GiftFilled","GiftOutlined","GiftTwoTone","GithubFilled","GithubOutlined","GitlabFilled","GitlabOutlined","GlobalOutlined","GoldFilled","GoldOutlined","GoldTwoTone","GoldenFilled","GoogleCircleFilled","GoogleOutlined","GooglePlusCircleFilled","GooglePlusOutlined","GooglePlusSquareFilled","GoogleSquareFilled","GroupOutlined","HddFilled","HddOutlined","HddTwoTone","HeartFilled","HeartOutlined","HeartTwoTone","HeatMapOutlined","HighlightFilled","HighlightOutlined","HighlightTwoTone","HistoryOutlined","HomeFilled","HomeOutlined","HomeTwoTone","HourglassFilled","HourglassOutlined","HourglassTwoTone","Html5Filled","Html5Outlined","Html5TwoTone","IdcardFilled","IdcardOutlined","IdcardTwoTone","IeCircleFilled","IeOutlined","IeSquareFilled","ImportOutlined","InboxOutlined","InfoCircleFilled","InfoCircleOutlined","InfoCircleTwoTone","InfoOutlined","InsertRowAboveOutlined","InsertRowBelowOutlined","InsertRowLeftOutlined","InsertRowRightOutlined","InstagramFilled","InstagramOutlined","InsuranceFilled","InsuranceOutlined","InsuranceTwoTone","InteractionFilled","InteractionOutlined","InteractionTwoTone","IssuesCloseOutlined","ItalicOutlined","KeyOutlined","LaptopOutlined","LayoutFilled","LayoutOutlined","LayoutTwoTone","LeftCircleFilled","LeftCircleOutlined","LeftCircleTwoTone","LeftOutlined","LeftSquareFilled","LeftSquareOutlined","LeftSquareTwoTone","LikeFilled","LikeOutlined","LikeTwoTone","LineChartOutlined","LineHeightOutlined","LineOutlined","LinkOutlined","LinkedinFilled","LinkedinOutlined","Loading3QuartersOutlined","LoadingOutlined","LockFilled","LockOutlined","LockTwoTone","LoginOutlined","LogoutOutlined","MacCommandFilled","MacCommandOutlined","MailFilled","MailOutlined","MailTwoTone","ManOutlined","MedicineBoxFilled","MedicineBoxOutlined","MedicineBoxTwoTone","MediumCircleFilled","MediumOutlined","MediumSquareFilled","MediumWorkmarkOutlined","MehFilled","MehOutlined","MehTwoTone","MenuFoldOutlined","MenuOutlined","MenuUnfoldOutlined","MergeCellsOutlined","MessageFilled","MessageOutlined","MessageTwoTone","MinusCircleFilled","MinusCircleOutlined","MinusCircleTwoTone","MinusOutlined","MinusSquareFilled","MinusSquareOutlined","MinusSquareTwoTone","MobileFilled","MobileOutlined","MobileTwoTone","MoneyCollectFilled","MoneyCollectOutlined","MoneyCollectTwoTone","MonitorOutlined","MoreOutlined","NodeCollapseOutlined","NodeExpandOutlined","NodeIndexOutlined","NotificationFilled","NotificationOutlined","NotificationTwoTone","NumberOutlined","OneToOneOutlined","OrderedListOutlined","PaperClipOutlined","PartitionOutlined","PauseCircleFilled","PauseCircleOutlined","PauseCircleTwoTone","PauseOutlined","PayCircleFilled","PayCircleOutlined","PercentageOutlined","PhoneFilled","PhoneOutlined","PhoneTwoTone","PicCenterOutlined","PicLeftOutlined","PicRightOutlined","PictureFilled","PictureOutlined","PictureTwoTone","PieChartFilled","PieChartOutlined","PieChartTwoTone","PlayCircleFilled","PlayCircleOutlined","PlayCircleTwoTone","PlaySquareFilled","PlaySquareOutlined","PlaySquareTwoTone","PlusCircleFilled","PlusCircleOutlined","PlusCircleTwoTone","PlusOutlined","PlusSquareFilled","PlusSquareOutlined","PlusSquareTwoTone","PoundCircleFilled","PoundCircleOutlined","PoundCircleTwoTone","PoundOutlined","PoweroffOutlined","PrinterFilled","PrinterOutlined","PrinterTwoTone","ProfileFilled","ProfileOutlined","ProfileTwoTone","ProjectFilled","ProjectOutlined","ProjectTwoTone","PropertySafetyFilled","PropertySafetyOutlined","PropertySafetyTwoTone","PullRequestOutlined","PushpinFilled","PushpinOutlined","PushpinTwoTone","QqCircleFilled","QqOutlined","QqSquareFilled","QrcodeOutlined","QuestionCircleFilled","QuestionCircleOutlined","QuestionCircleTwoTone","QuestionOutlined","RadarChartOutlined","RadiusBottomleftOutlined","RadiusBottomrightOutlined","RadiusSettingOutlined","RadiusUpleftOutlined","RadiusUprightOutlined","ReadFilled","ReadOutlined","ReconciliationFilled","ReconciliationOutlined","ReconciliationTwoTone","RedEnvelopeFilled","RedEnvelopeOutlined","RedEnvelopeTwoTone","RedditCircleFilled","RedditOutlined","RedditSquareFilled","RedoOutlined","ReloadOutlined","RestFilled","RestOutlined","RestTwoTone","RetweetOutlined","RightCircleFilled","RightCircleOutlined","RightCircleTwoTone","RightOutlined","RightSquareFilled","RightSquareOutlined","RightSquareTwoTone","RiseOutlined","RobotFilled","RobotOutlined","RocketFilled","RocketOutlined","RocketTwoTone","RollbackOutlined","RotateLeftOutlined","RotateRightOutlined","SafetyCertificateFilled","SafetyCertificateOutlined","SafetyCertificateTwoTone","SafetyOutlined","SaveFilled","SaveOutlined","SaveTwoTone","ScanOutlined","ScheduleFilled","ScheduleOutlined","ScheduleTwoTone","ScissorOutlined","SearchOutlined","SecurityScanFilled","SecurityScanOutlined","SecurityScanTwoTone","SelectOutlined","SendOutlined","SettingFilled","SettingOutlined","SettingTwoTone","ShakeOutlined","ShareAltOutlined","ShopFilled","ShopOutlined","ShopTwoTone","ShoppingCartOutlined","ShoppingFilled","ShoppingOutlined","ShoppingTwoTone","ShrinkOutlined","SignalFilled","SisternodeOutlined","SketchCircleFilled","SketchOutlined","SketchSquareFilled","SkinFilled","SkinOutlined","SkinTwoTone","SkypeFilled","SkypeOutlined","SlackCircleFilled","SlackOutlined","SlackSquareFilled","SlackSquareOutlined","SlidersFilled","SlidersOutlined","SlidersTwoTone","SmallDashOutlined","SmileFilled","SmileOutlined","SmileTwoTone","SnippetsFilled","SnippetsOutlined","SnippetsTwoTone","SolutionOutlined","SortAscendingOutlined","SortDescendingOutlined","SoundFilled","SoundOutlined","SoundTwoTone","SplitCellsOutlined","StarFilled","StarOutlined","StarTwoTone","StepBackwardFilled","StepBackwardOutlined","StepForwardFilled","StepForwardOutlined","StockOutlined","StopFilled","StopOutlined","StopTwoTone","StrikethroughOutlined","SubnodeOutlined","SwapLeftOutlined","SwapOutlined","SwapRightOutlined","SwitcherFilled","SwitcherOutlined","SwitcherTwoTone","SyncOutlined","TableOutlined","TabletFilled","TabletOutlined","TabletTwoTone","TagFilled","TagOutlined","TagTwoTone","TagsFilled","TagsOutlined","TagsTwoTone","TaobaoCircleFilled","TaobaoCircleOutlined","TaobaoOutlined","TaobaoSquareFilled","TeamOutlined","ThunderboltFilled","ThunderboltOutlined","ThunderboltTwoTone","ToTopOutlined","ToolFilled","ToolOutlined","ToolTwoTone","TrademarkCircleFilled","TrademarkCircleOutlined","TrademarkCircleTwoTone","TrademarkOutlined","TransactionOutlined","TranslationOutlined","TrophyFilled","TrophyOutlined","TrophyTwoTone","TwitterCircleFilled","TwitterOutlined","TwitterSquareFilled","UnderlineOutlined","UndoOutlined","UngroupOutlined","UnlockFilled","UnlockOutlined","UnlockTwoTone","UnorderedListOutlined","UpCircleFilled","UpCircleOutlined","UpCircleTwoTone","UpOutlined","UpSquareFilled","UpSquareOutlined","UpSquareTwoTone","UploadOutlined","UsbFilled","UsbOutlined","UsbTwoTone","UserAddOutlined","UserDeleteOutlined","UserOutlined","UserSwitchOutlined","UsergroupAddOutlined","UsergroupDeleteOutlined","VerifiedOutlined","VerticalAlignBottomOutlined","VerticalAlignMiddleOutlined","VerticalAlignTopOutlined","VerticalLeftOutlined","VerticalRightOutlined","VideoCameraAddOutlined","VideoCameraFilled","VideoCameraOutlined","VideoCameraTwoTone","WalletFilled","WalletOutlined","WalletTwoTone","WarningFilled","WarningOutlined","WarningTwoTone","WechatFilled","WechatOutlined","WeiboCircleFilled","WeiboCircleOutlined","WeiboOutlined","WeiboSquareFilled","WeiboSquareOutlined","WhatsAppOutlined","WifiOutlined","WindowsFilled","WindowsOutlined","WomanOutlined","YahooFilled","YahooOutlined","YoutubeFilled","YoutubeOutlined","YuqueFilled","YuqueOutlined","ZhihuCircleFilled","ZhihuOutlined","ZhihuSquareFilled","ZoomInOutlined","ZoomOutOutlined"]

三、图标选择器组件使用

1、引入图标选择组件

import iconSelect from '../iconPicker/iconPicker.vue';

2、注册组件

3、接收子组件传值,(点击图标时,将被选中图标名称返回给父级组件)

此处是将选择器组件放到一个弹出层中,因此在子组件回传的时候要记得把弹窗进行关闭,并将子组件的值赋值给父级组件

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。