【问题标题】:Delay JSX evaluation延迟 JSX 评估
【发布时间】:2021-05-17 05:46:44
【问题描述】:

我有一个函数可以将 JSX 返回到一些 React 组件。我意识到我还需要在 JSX 中包含这些组件的一些状态变量。每个组件可能需要更改 JSX 或其中的值(或两者)。请参阅下面的代码。

export function getDisplayBlock(a: number) {
  if (a == 1) {
    return <>{title}</>;
  } else if (a == 2) {
    return (
      <>
        {title}
        {subtitle}
      </>
    );
  } else if (a == 3) {
    return (
      <>
        <img src={companyLogo} />
        {caption}
      </>
    );
  }
}

这不起作用,因为在 getDisplayBlock 中,titlesubtitlecompanyLogocaption 是未知的。 我考虑过的一些解决方法:

  • 将所有这些 (title,subtitle) 作为另一个参数传递给函数。这需要在每次更新这些变量时调用函数

  • 返回一个字符串而不是 JSX,并用正则表达式替换参数值,然后使用dangerouslySetInnerHTML

  • “Hack it”(这里的好处是你调用一次函数来获取组件需要的 JSX):

    export function getDisplayBlock(this: any, a: number) {
      if (a == 1) {
        return () => <>{this.state.title}</>;
      } else if (a == 2) {
        return () => (
          <>
            {this.state.title}
            {this.state.subtitle}
          </>
        );
      } else {
        return () => (
          <>
            <img src={this.state.companyLogo} />
            {this.state.caption}
          </>
        );
      }
    }
    

任何想法表示赞赏!

【问题讨论】:

  • 为什么这些变量在你的函数中是未知的?如果要更改,则应将它们用作状态
  • 一个函数渲染三个不同的组件对我来说似乎很奇怪。但是,您可以将所有这些值作为对象的属性传递。 IE。你只有一个参数,它是一个具有所需属性的对象。
  • @TheTisi都处于调用这个函数的组件的状态
  • @FelixKling 这是建议的解决方案 1。在这种情况下,当客户端在运行时更改这些值时,它们不会在 JSX 中更新!
  • 好吧,如果任何值发生变化,我希望再次调用该函数,从而生成一个新元素。它与您提出的第三个解决方案没有什么不同,只是对象是通过this 显式传递的。

标签: reactjs typescript jsx


【解决方案1】:

如果不调用函数,就无法刷新函数的返回值。您可以检查一下 React.Context 之类的内容是否是您感兴趣的内容,尽管它不会真正提高对渲染代码的调用量并因此提高性能(这是问题吗?)。

我不完全理解用例,即如果父组件总是只渲染一个 jsx 返回值,然后将它们分散到单独的组件中,而不是将它们放在同一个函数中。

最终结果将是相同的,每次状态更新时都需要调用该函数。但是代码会干净很多。

更新每个刷新的问题: 如果你想控制传入的 JSX,也许在子组件中渲染子组件会为你工作:

const GetDisplayBlock = props => {
    const { a } = props;
    return (
      <>
        {a == 1 ? (
          <>{props.children}</>
        ) : a == 2 ? (
          <>
            <diV>{props.children}</diV>
          </>
        ) : (
          <>
            <p>{props.children}</p>
          </>
        )}
      </>
    );
  };
...

那么在渲染调用中,你可以这样调用:

<GetDisplayBlock a={3}>
  <div>buyaka</div>
</GetDisplayBlock>

【讨论】:

  • 谢谢!是的,关注的是性能,因为这是一个简化的例子 :) 我编辑了我的问题,说确实 JSX 或其中的变量值可能会改变 - 这是我的错误。
  • 我已经更新了我的答案,建议使用 props.children ,从而决定在父组件中渲染哪些子组件。看看这是否有效。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-03-03
  • 1970-01-01
  • 2016-06-20
  • 2014-10-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多