自定义导入的样式化组件

时间:2019-06-19 11:32:38

标签: javascript reactjs styled-components

我有一个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组件赋予唯一样式时,为什么不能正常工作?

0 个答案:

没有答案