Icon List @douyinfe/semi-icons icon list:
IconAbsoluteStroked
IconActivity
IconAlarm
IconAlertCircle
IconAlertTriangle
IconAlignBottom
IconAlignCenter
IconAlignCenterVertical
IconAlignHCenterStroked
IconAlignHLeftStroked
IconAlignHRightStroked
IconAlignJustify
IconAlignLeft
IconAlignRight
IconAlignTop
IconAlignVBotStroked
IconAlignVBottomStroked
IconAlignVCenterStroked
IconAlignVTopStroked
IconApartment
IconAppCenter
IconApps
IconArchive
IconArrowDown
IconArrowDownLeft
IconArrowDownRight
IconArrowLeft
IconArrowRight
IconArrowUp
IconArrowUpLeft
IconArrowUpRight
IconArticle
IconAscend
IconAt
IconBackTop
IconBackward
IconBarChartHStroked
IconBarChartVStroked
IconBeaker
IconBell
IconBellStroked
IconBold
IconBolt
IconBookH5Stroked
IconBookOpenStroked
IconBookStroked
IconBookmark
IconBookmarkAddStroked
IconBookmarkDeleteStroked
IconBottomCenterStroked
IconBottomLeftStroked
IconBottomRightStroked
IconBox
IconBrackets
IconBranch
IconBriefStroked
IconBriefcase
IconBulb
IconButtonStroked
IconBytedanceLogo
IconCalendar
IconCalendarClock
IconCalendarStroked
IconCamera
IconCandlestickChartStroked
IconCaretdown
IconCaretup
IconCarouselStroked
IconCart
IconCaseSensitive
IconCenterLeftStroked
IconCenterRightStroked
IconChainStroked
IconCheckChoiceStroked
IconCheckCircleStroked
IconCheckList
IconCheckboxIndeterminate
IconCheckboxTick
IconChecklistStroked
IconChevronDown
IconChevronDownStroked
IconChevronLeft
IconChevronRight
IconChevronRightStroked
IconChevronUp
IconChevronUpDown
IconClear
IconClock
IconClose
IconCloud
IconCloudStroked
IconCloudUploadStroked
IconCode
IconCodeStroked
IconCoinMoneyStroked
IconColorPalette
IconColumnsStroked
IconCommand
IconComment
IconCommentStroked
IconComponent
IconComponentPlaceholderStroked
IconComponentStroked
IconConfigStroked
IconConnectionPoint1
IconConnectionPoint2
IconContrast
IconCopy
IconCopyAdd
IconCopyStroked
IconCornerRadiusStroked
IconCreditCard
IconCrop
IconCrossCircleStroked
IconCrossStroked
IconCrown
IconCustomerSupport
IconCustomerSupportStroked
IconCustomize
IconDelete
IconDeleteStroked
IconDescend
IconDescend2
IconDesktop
IconDisc
IconDislikeThumb
IconDivide
IconDongchediLogo
IconDoubleChevronLeft
IconDoubleChevronRight
IconDownCircleStroked
IconDownload
IconDownloadStroked
IconDuration
IconEdit
IconEdit2Stroked
IconEditStroked
IconElementStroked
IconEmoji
IconExit
IconExpand
IconExport
IconExternalOpen
IconExternalOpenStroked
IconEyeClosed
IconEyeClosedSolid
IconEyeOpened
IconEyedropper
IconFacebook
IconFaceuLogo
IconFastForward
IconFastFoward
IconFavoriteList
IconFeishuLogo
IconFemale
IconFigma
IconFile
IconFillStroked
IconFilledArrowDown
IconFilledArrowUp
IconFilpVertical
IconFilter
IconFingerLeftStroked
IconFixedStroked
IconFlag
IconFlipHorizontal
IconFlowChartStroked
IconFolder
IconFolderOpen
IconFolderStroked
IconFollowStroked
IconFont
IconFontColor
IconForward
IconForwardStroked
IconFullScreenStroked
IconGallery
IconGift
IconGiftStroked
IconGit
IconGithubLogo
IconGitlabLogo
IconGlobe
IconGlobeStroke
IconGridRectangle
IconGridSquare
IconGridStroked
IconGridView
IconGridView1
IconH1
IconH2
IconH3
IconH4
IconH5
IconH6
IconH7
IconH8
IconH9
IconHandle
IconHash
IconHeartStroked
IconHelm
IconHelpCircle
IconHelpCircleStroked
IconHistogram
IconHistory
IconHn
IconHome
IconHomeStroked
IconHorn
IconHourglass
IconHourglassStroked
IconIdCard
IconIdentity
IconImage
IconImageStroked
IconImport
IconInbox
IconIndenpentCornersStroked
IconIndentLeft
IconIndentRight
IconIndependentCornersStroked
IconInfoCircle
IconInherit
IconInheritStroked
IconInnerSectionStroked
IconInstagram
IconInteractiveStroked
IconInviteStroked
IconIssueStroked
IconItalic
IconJianying
IconKanban
IconKey
IconKeyStroked
IconLanguage
IconLayers
IconLeftCircleStroked
IconLightningStroked
IconLikeHeart
IconLikeThumb
IconLineChartStroked
IconLineHeight
IconLink
IconList
IconListView
IconLive
IconLoading
IconLock
IconLockStroked
IconLoopTextStroked
IconMail
IconMailStroked
IconMailStroked1
IconMale
IconMapPin
IconMapPinStroked
IconMarginLeftStroked
IconMarginStroked
IconMark
IconMaximize
IconMember
IconMenu
IconMicrophone
IconMicrophoneOff
IconMinimize
IconMinus
IconMinusCircle
IconMinusCircleStroked
IconMinusStroked
IconModalStroked
IconMoneyExchangeStroked
IconMonitorStroked
IconMoon
IconMore
IconMoreStroked
IconMusic
IconMusicNoteStroked
IconMute
IconNineGridStroked
IconNoteMoneyStroked
IconOption
IconOrderedList
IconOrderedListStroked
IconPaperclip
IconPause
IconPercentage
IconPhone
IconPhoneStroke
IconPieChart2Stroked
IconPieChartStroked
IconPiechartH5Stroked
IconPipixiaLogo
IconPlay
IconPlayCircle
IconPlus
IconPlusCircle
IconPlusCircleStroked
IconPlusStroked
IconPriceTag
IconPrint
IconPrizeStroked
IconPulse
IconPuzzle
IconQingyan
IconQrCode
IconQuit
IconQuote
IconRadio
IconRankingCardStroked
IconRealSizeStroked
IconRedo
IconRedoStroked
IconRefresh
IconRefresh2
IconRegExp
IconReply
IconReplyStroked
IconResso
IconRestart
IconRingChartStroked
IconRotate
IconRotationStroked
IconRoute
IconRowsStroked
IconSafe
IconSave
IconSaveStroked
IconScan
IconScissors
IconSearch
IconSearchStroked
IconSectionStroked
IconSemiLogo
IconSend
IconSendMsgStroked
IconSendStroked
IconServer
IconServerStroked
IconSetting
IconSettingStroked
IconShareMoneyStroked
IconShareStroked
IconShield
IconShieldStroked
IconShift
IconShoppingBag
IconShrink
IconShrinkScreenStroked
IconSidebar
IconSignal
IconSimilarity
IconSmallTriangleDown
IconSmallTriangleLeft
IconSmallTriangleRight
IconSmallTriangleTop
IconSmartphoneCheckStroked
IconSmartphoneStroked
IconSong
IconSonicStroked
IconSort
IconSortStroked
IconSourceControl
IconSpin
IconStackBarChartStroked
IconStar
IconStarStroked
IconStop
IconStopwatchStroked
IconStoryStroked
IconStrikeThrough
IconSun
IconSync
IconTabArrowStroked
IconTabsStroked
IconTaskMoneyStroked
IconTemplate
IconTemplateStroked
IconTerminal
IconTestScoreStroked
IconText
IconTextRectangle
IconTextStroked
IconThumbUpStroked
IconTick
IconTickCircle
IconTicketCodeExchangeStroked
IconTicketCodeStroked
IconTiktokLogo
IconTop
IconTopCenterStroked
IconTopLeftStroked
IconTopRightStroked
IconTopbuzzLogo
IconToutiaoLogo
IconTransparentStroked
IconTreeTriangleDown
IconTreeTriangleRight
IconTriangleArrow
IconTriangleArrowVertical
IconTriangleDown
IconTriangleUp
IconTrueFalseStroked
IconTvCheckedStroked
IconTwitter
IconTypograph
IconUnChainStroked
IconUnderline
IconUndo
IconUnlink
IconUnlock
IconUnlockStroked
IconUpload
IconUploadError
IconUser
IconUserAdd
IconUserCardPhone
IconUserCardVideo
IconUserCircle
IconUserCircleStroked
IconUserGroup
IconUserListStroked
IconUserSetting
IconUserStroked
IconVennChartStroked
IconVerify
IconVersionStroked
IconVideo
IconVideoDouyinStroked
IconVideoListStroked
IconVideoStroked
IconVideoUrlStroked
IconVigoLogo
IconVolume1
IconVolume2
IconVolumnSilent
IconVoteStroked
IconVoteVideoStroked
IconWeibo
IconWholeWord
IconWifi
IconWindowAdaptionStroked
IconWrench
IconXiguaLogo
IconYoutube
@douyinfe/semi-icons-lab icon list:
IconAccessibility
IconAnchor
IconAutocomplete
IconAvatar
IconBackTop
IconBadge
IconBadgeStar
IconBanner
IconBreadcrumb
IconButton
IconCalendar
IconCard
IconCarousel
IconCascader
IconChangelog
IconChart
IconChat
IconCheckbox
IconCodeHighlight
IconCollapse
IconCollapsible
IconColorPlatte
IconColorPlatteNew
IconConfig
IconDarkMode
IconDatePicker
IconDescriptions
IconDivider
IconDropdown
IconEmpty
IconFaq
IconForm
IconGettingStarted
IconGrid
IconHeart
IconHighlight
IconImage
IconInput
IconInputNumber
IconIntro
IconJsonViewer
IconLayout
IconList
IconLocaleProvider
IconLottie
IconMarkdown
IconModal
IconNavigation
IconNotification
IconOverflow
IconPagination
IconPincode
IconPopconfirm
IconPopover
IconProgress
IconRadio
IconRating
IconScrollList
IconSelect
IconSideSheet
IconSkeleton
IconSlider
IconSpace
IconSpin
IconSteps
IconSwitch
IconTable
IconTabs
IconTag
IconTagInput
IconTimePicker
IconTimeline
IconToast
IconToken
IconTooltip
IconTransfer
IconTree
IconTreeSelect
IconTypography
IconUpload
IconVersionOne
IconVersionTwo
IconWebcomponents
IconWheelChair
Accessibility Alert Arrow Basic Brands Building Business Code Communication Device Files&Folder Interface Layout Music Objects Photo&Video Time User Writing Basic Chart & Diagram Editor Magic Customized Colorful Icons Common Demos How to import import Icon, { IconHome } from '@douyinfe/semi-icons';
Basic usage Import icons from the @douyinfe/semi-icons
package
import React from 'react';
import { IconHome } from '@douyinfe/semi-icons';
() => <IconHome />;
Rotate & Spin Introduce icons from the @douyinfe/semi-icons
package, with its own size, rotation, and spin functions
import React from 'react';
import { IconHome, IconEmoji, IconSpin } from '@douyinfe/semi-icons';
() => (
<div>
<IconHome size="small" />
<IconEmoji rotate={180} />
<IconSpin spin />
</div>
);
Size You can change the font-size
to change the icon size
The Icon component encapsulates the size attribute, which makes it easier to define the icon size. It supports extra-small
(8x8), small
(12x12), default
(16x16), large
(20x20), extra-large
(24x24), When size is specified as inherit
, the icon size inherits the current context font size.
import React from 'react';
import { IconSearch, IconHelpCircle, IconAlertCircle, IconMinusCircle, IconPlusCircle, IconPlus, IconRefresh } from '@douyinfe/semi-icons';
() => {
// eslint-disable-next-line react/jsx-key
const types = [<IconSearch />, <IconHelpCircle />, <IconAlertCircle />, <IconMinusCircle />, <IconPlusCircle />, <IconPlus />, <IconRefresh />];
const sizes = ['extra-small', 'small', 'default', 'large', 'extra-large'];
let icons = types.map((type, i) => {
return <div key={i} style={{ marginBottom: 4 }}>{sizes.map(size => React.cloneElement(type, { size, key: size }))}</div>;
});
return icons;
};
Color The icon will automatically inherit the color
property of the external container CSS
You can also modify the color of the icon by setting style props to the Icon.
import React from 'react';
import { IconLikeHeart, IconFlag, IconLock, IconUnlock } from '@douyinfe/semi-icons';
() => (
<div>
<div style={{ color: '#E91E63' }} >
<IconLikeHeart size="extra-large"/>
<IconFlag size="extra-large"/>
</div>
<br/>
<div>
<IconLock style={{ color: '#6A3AC7' }} size="extra-large" />
<IconUnlock style={{ color: '#9C27B0' }} size="extra-large"/>
</div>
</div>
);
Custom icon You can use custom icons to pass in Icon components
Icon component supports size, rotate, spin and other attributes
import React from 'react';
import { Icon } from '@douyinfe/semi-ui';
() => {
function CustomIcon() {
return <svg width="1em" height="1em" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<circle cx="12" cy="12" r="11" fill="#FBCD2C"/>
<mask id="mask0" masktype="alpha" maskUnits="userSpaceOnUse" x="1" y="1" width="22" height="22">
<circle cx="12" cy="12" r="11" fill="#A2845E"/>
</mask>
<g mask="url(#mask0)">
<path fillRule="evenodd" clipRule="evenodd" d="M11.9996 17.7963C13.7184 17.7963 15.2479 16.3561 16.0881 14.2048C16.6103 13.9909 17.1072 13.3424 17.334 12.4957C17.629 11.3948 17.5705 10.4118 16.7665 10.1059C16.6885 6.27115 15.1754 4.78714 11.9996 4.78714C8.82412 4.78714 7.31097 6.27097 7.2328 10.1052C6.42711 10.4103 6.36828 11.394 6.66349 12.4957C6.89064 13.3435 7.38849 13.9926 7.91145 14.2056C8.7518 16.3565 10.2811 17.7963 11.9996 17.7963ZM20.0126 23C20.34 23 20.5906 22.7037 20.4686 22.3999C19.6099 20.2625 16.1444 18.6636 12 18.6636C7.85555 18.6636 4.39008 20.2625 3.53142 22.3999C3.40937 22.7037 3.65999 23 3.9874 23H20.0126Z" fill="white"/>
</g>
</svg>;
}
return (
<div>
<Icon svg={<CustomIcon />} />
<Icon svg={<CustomIcon />} rotate={180} />
</div>
);
};
Use svgr to convert svg files into ReactComponent If the icons provided by Semi are not enough to meet business needs, you can also introduce custom icons through @svgr/webpack and use them as React components
// webpack.config.js
{
test: /\.svg$/,
use: ['@svgr/webpack'],
}
import { Icon } from '@douyinfe/semi-ui';
import StarIcon from './star.svg';
<Icon svg={<StarIcon />} />
API reference Icon Properties Illustrate Type Default className class name string none onClick Callback event of clicking the icon (e: Event) => void None onMouseDown The callback event of mouse button press >=v1.21 (e: Event) => void None onMouseEnter Callback event of entering icon (e: Event) => void None onMouseLeave Callback event of leaving icon (e: Event) => void None onMouseMove Callback event of moving the mouse >=v1.21 (e: Event) => void None onMouseUp Callback event when the mouse button is raised >=v1.21 (e: Event) => void None rotate degree of rotation number size Size, supports inherit
, extra-small
, small
, default
, large
, extra-large
string default
spin spin animation boolean style Icon style CSSProperties None svg Icon content ReactNode None
Accessibility ARIA The Icon component role is img, and its aria-label defaults to the component's file name import React from 'react';
import { IconHome } from '@douyinfe/semi-icons';
() => <IconHome aria-label="back to homepage" />;
The svg element inside Icon is a decorative element, and aria-hidden is set by default to prevent it from being read by screen readers