【问题标题】:Conditionally render JSX on specific routes有条件地在特定路由上渲染 JSX
【发布时间】:2020-12-10 10:25:16
【问题描述】:

我为 SplitScreen 页面构建了一个 React 组件布局(屏幕截图的底部布局设计)。

问题是 LoginPage 布局(屏幕截图上的顶部布局设计)我不需要 backArrowIcon 在顶部,您可以在第二个屏幕截图上更好地看到。

我还必须更改 LoginPage 容器屏幕上的左拆分显示。

谁知道我可以做些什么来解决我的两个问题?

这也是我的 SplitScreen 组件代码:

import React from 'react';
import { Link, useHistory, withRouter } from 'react-router-dom';

import logoImg from '../../assets/images/logo.svg';
import backIcon from '../../assets/images/icons/back.svg';

import './styles.css';

function SplitScreen(props: { children: React.ReactNode; }) {
  return (
    <section className="split-page-container">
      <div className="right-side">
        <Link
          className="back-arrow"                 // Here's the backArrowIcon
          to="/">
          <img src={backIcon} alt="Voltar" />
        </Link>
        <div className="proffy">
          <div className="proffy-fundo">
            <img src={logoImg} alt="Proffy Logo" />
            <h2>Sua plataforma de <br /> estudos online.</h2>
          </div>
        </div>
      </div>

      <div className="left-side">
        <div className="content-box">
          {props.children}
        </div>
      </div>
    </section>
  );
}

export default SplitScreen;

这是我的 CSS:

.split-page-container {
  width: 100vw;
  height: 100vh;

  display: flex;
  flex-flow: column nowrap;
}

.left-side, .right-side {
  display: flex;
  flex-direction: column;
  flex: 1;
  align-items: center;
  justify-content: center;
}

.left-side {
  background: var(--color-background);
}

.right-side {
  background: var(--color-primary);
}

.content-box {
  padding: 5.6rem 3.2rem;
}

.back-arrow {
  align-self: flex-start;
  padding: 1.2rem 1.8rem;
  height: 0;
  color: var(--color-text-in-primary);
}

.right-side a {
  transition: opacity 0.2s;
}

.right-side a:hover {
  opacity: 0.6;
}

.proffy {
  height: 37.9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.proffy-fundo {
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  width: 23.8rem;
  height: 26.6rem;
  background-image: url('../../assets/images/success-background.svg');
  background-position: center;
  background-size: contain;
}

.proffy-fundo img {
  width: 16rem;
}

.proffy-fundo h2 {
  width: 16rem;
  
  text-align: left;
  font-weight: 500;
  font-size: 1.6rem;
  margin-top: 0.8rem;

  color: var(--color-text-in-primary);
}

@media (min-width: 1100px) {
  .split-page-container {
    flex-flow: row-reverse nowrap;       // How can I delete this .split-page-container styling on
  }                                      // my LoginPage container?

  .back-arrow {
    color: var(--color-primary-darker);
    transform: translate(-39vw, -23vh);
  }

  .right-side a {
    transition: opacity 0.2s;
  }
  
  .right-side a:hover {
    opacity: 0.8;
  }

  .proffy-fundo {
    width: 40rem;
    height: 58.4rem;
  }

  .proffy-fundo img {
    width: 33.4rem;
  }

  .proffy-fundo h2 {
    width: 33.4rem;

    text-align: left;
    font-weight: 500;
    font-size: 2.4rem;
    line-height: 3.4rem;
    margin-top: 0.8rem;
  }
}

【问题讨论】:

    标签: css reactjs typescript react-router styled-components


    【解决方案1】:

    您可以使用位置路径名并检查是否在您的登录路径上。

    useLocation

    如果不在您的登录路径上,则有条件地呈现后退按钮。

    import React from 'react';
    import { Link, useLocation, useHistory, withRouter } from 'react-router-dom';
    
    import logoImg from '../../assets/images/logo.svg';
    import backIcon from '../../assets/images/icons/back.svg';
    
    import './styles.css';
    
    function SplitScreen(props: { children: React.ReactNode; }) {
      const { pathname } = useLoction();
    
      const showBack = !pathname.startsWith("/login");
    
      return (
        <section className="split-page-container">
          <div className="right-side">
            {showBack && (
              <Link
                className="back-arrow"
                to="/">
                <img src={backIcon} alt="Voltar" />
              </Link>
            )}
            <div className="proffy">
              <div className="proffy-fundo">
                <img src={logoImg} alt="Proffy Logo" />
                <h2>Sua plataforma de <br /> estudos online.</h2>
              </div>
            </div>
          </div>
    
          <div className="left-side">
            <div className="content-box">
              {props.children}
            </div>
          </div>
        </section>
      );
    }
    

    如果你只是想交换左右两边,你可以交换类名。

    function SplitScreen(props: { children: React.ReactNode; }) {
      const { pathname } = useLoction();
    
      const showBack = !pathname.startsWith("/login");
    
      return (
        <section className="split-page-container">
          <div className="left-side"> // <-- now the left side
            {showBack && (
              <Link
                className="back-arrow"
                to="/">
                <img src={backIcon} alt="Voltar" />
              </Link>
            )}
            <div className="proffy">
              <div className="proffy-fundo">
                <img src={logoImg} alt="Proffy Logo" />
                <h2>Sua plataforma de <br /> estudos online.</h2>
              </div>
            </div>
          </div>
    
          <div className="right-side"> // <-- now the right side
            <div className="content-box">
              {props.children}
            </div>
          </div>
        </section>
      );
    }
    

    【讨论】:

    • 非常感谢德鲁先生!但是我只想在我的登录页面上交换屏幕侧面,那怎么不影响我的其他页面呢?
    • 我刚刚解决了在登录页面上翻转页面的问题: let splitPageClassName = "split-page-container"; if (!notLoginPath) { splitPageClassName = "login-split-page-container"; } 并说 ... 然后将 .login-split-page-container 添加到我的 CSS 谢谢你的人!没有您的支持,我们无法成功!
    • @FernandoRodriguesCoelho 抱歉,我无法更快地做出响应,但是,是的,我错过了这是通用页面容器与特定页面实例相比的部分。我会暴露一个布尔属性来交换面板,即swapPanels,并简单地设置类名,即第一部分的className={swapPanels ? "left-side" : "right-side"}和第二部分的className={swapPanels ? "right-side" : "left-side"}。我可能还会继续基于道具显示/隐藏后退按钮。这有助于将可视化 UI 组件与任何特定用例分离。
    • 非常感谢你,你真的帮助了我!
    • @FernandoRodriguesCoelho 欢迎您。很高兴能提供帮助。
    猜你喜欢
    • 2018-06-30
    • 2018-04-18
    • 2020-01-12
    • 1970-01-01
    • 2020-10-12
    • 2020-11-06
    • 2023-03-22
    • 2015-05-16
    • 2020-12-16
    相关资源
    最近更新 更多