使用 Themeprovider 和样式化组件实现暗模式

Posted

技术标签:

【中文标题】使用 Themeprovider 和样式化组件实现暗模式【英文标题】:implementing dark mode with Themeprovider and styled components 【发布时间】:2020-10-23 18:20:17 【问题描述】:

我对样式组件了解不多,我正在使用切换开关来更改主题,并且我的主题确实从深色切换到浅色,但我使用的图标不会切换图标。图标是有效的,当我切换组件的顺序时,月亮图标只显示,我猜这是有语法的东西?

import React from 'react'
import  func, string  from 'prop-types';
import styled from 'styled-components';
import  ReactComponent as MoonIcon  from '../components/icons/moon.svg';
import  ReactComponent as SunIcon  from '../components/icons/sun.svg';

const ToggleContainer = styled.button`
  background: $( theme ) => theme.gradient;
  border: 2px solid $( theme ) => theme.toggleBorder;
  border-radius: 30px;
  cursor: pointer;
  display: flex;
  font-size: 0.5rem;
  justify-content: space-between;
  margin: 0 auto;
  overflow: hidden;
  padding: 0.5rem;
  position: relative;
  width: 8rem;
  height: 4rem;

  svg 
    height: auto;
    width: 2.5rem;
    transition: all 0.3s linear;
    
    // sun icon
    &:first-child 
      transform: $( lightTheme ) => lightTheme ? 'translateY(0)' : 'translateY(100px)';
    
    
    // moon icon
    &:nth-child(2) 
      transform: $( lightTheme ) => lightTheme ? 'translateY(-100px)' : 'translateY(0)';
    
  
`;
const Toggle = ( theme, toggleTheme ) => 
    
  const isLight = theme === 'light';
  return (
    <ToggleContainer onClick=toggleTheme >
      <MoonIcon />
      <SunIcon />
    </ToggleContainer>
  );
;

Toggle.propTypes = 
  theme: string.isRequired,
  toggleTheme: func.isRequired,


export default Toggle;

lightmode

darkmode

【问题讨论】:

大声笑我也有同样的问题,你知道了吗? 【参考方案1】:

在此代码中添加lightTheme=isLight

在:&lt;ToggleContainer onClick=toggleTheme &gt;

决赛:&lt;ToggleContainer onClick=toggleTheme lightTheme=isLight&gt;

另外,你可以使用下面的变换来切换,

`&:first-child 
  transform: $( lightTheme ) => lightTheme ? 'translateX(0px)' : 'translateX(-150px)';
    

&:nth-child(2) 
  transform: $( lightTheme ) => lightTheme ? 'translateX(100px)' : 'translateX(0px)';
`

【讨论】:

以上是关于使用 Themeprovider 和样式化组件实现暗模式的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Enzymes shallow 和 styled-component 的 ThemeProvider 测试样式化组件?

在样式化组件 UI 库上使用 ThemeProvider

样式化组件中的动态主题

包括对带有 typescript 的样式化组件主题的媒体查询

已发布的样式组件反应库无权访问用户应用程序 ThemeProvider

如何处理样式组件中的条件