我有一个Icon
组件要导入到“联系人页面”中。我希望Icon
组件仅对该页面具有独特的样式。我也在使用Styled-Components
。
这样,我想我会在导入Icon组件后对其进行扩展,如下所示:
import { Icon } from 'Elements'
const ContactIcon = styled(Icon)`
// Unique CSS Styles
`
<ContactIcon glyph={Email} screen="Email" />
问题是Icon组件没有被注册-正如我们所看到的,如果我们看一下获取输出的html:
<span class="ContactForm__ContactIcon-eDVBAa fAJSOh"></span>
但是,如果我使用原始的Icon
组件,则一切正常。即,这可行:
<Icon glyph={Email} screen="Email" />
这是<Icon>
组件生成的html:
<span class="Icon__IconLink-hOjoyw ewcGUr"><span class="Icon__ScreenReader-cKVXXE lfVDCI">Email</span><svg stroke="currentColor" fill="currentColor" stroke-width="0" viewBox="0 0 512 512" height="1em" width="1em" xmlns="http://www.w3.org/2000/svg"><path d="M464 64H48C21.49 64 0 85.49 0 112v288c0 26.51 21.49 48 48 48h416c26.51 0 48-21.49 48-48V112c0-26.51-21.49-48-48-48zm0 48v40.805c-22.422 18.259-58.168 46.651-134.587 106.49-16.841 13.247-50.201 45.072-73.413 44.701-23.208.375-56.579-31.459-73.413-44.701C106.18 199.465 70.425 171.067 48 152.805V112h416zM48 400V214.398c22.914 18.251 55.409 43.862 104.938 82.646 21.857 17.205 60.134 55.186 103.062 54.955 42.717.231 80.509-37.199 103.053-54.947 49.528-38.783 82.032-64.401 104.947-82.653V400H48z"></path></svg></span>
作为进一步的背景信息,这是我要导入的原始Icon
组件:
import React from 'react'
import styled from 'styled-components'
const ScreenReader = styled.span`
// CSS Styles
`
const IconLink = styled.a`
// CSS Styles
`
export const Icon = props => (
<IconLink href={props.goTo} {...props}>
<ScreenReader>{props.screen}</ScreenReader>
<props.glyph />
</IconLink>
)
我还应该补充一点,这些图标是由react-icons
提供的。这就是glyph
道具所指的。
所以,我想知道-当我使用样式化组件为导入的React Icon组件赋予唯一样式时,为什么不能正常工作?