So zeigen Sie React-Komponenten an
P粉982054449
P粉982054449 2023-09-16 22:40:46
0
2
608

Können folgende Inhalte so angezeigt werden: jsx?

//编写一个返回`jsx`的js函数
function child(label, value){
  return (
    <h3>
     {label}: {value}
    </h3>
  )
}

export default function Parent(){
  const [state, setState] = useState({label:"", value:""})
  const {label, value} = state;
  
  return (
    // 然后调用函数显示`jsx`
    <>{test(label, value)}</>
  )
}

Oder ist es besser, React-Funktionskomponenten zu schreiben:

function Child({state}){
  return (
    <h3>
     {state.label}: {state.value}
    </h3>
  )
}

export default function Parent(){
  const [state, setState] = useState({label:"", value:""})
  
  return (
    <Child state={state} />
  )
}
P粉982054449
P粉982054449

Antworte allen(2)
P粉545910687

第二种方法看起来更简单和可读。记住,你让代码更可读,项目变得越大,它就越容易管理。此外,这种方法是构建React组件的最常见做法。

P粉413704245

最佳实践是将其渲染为一个React组件。

原因是,虽然仅使用函数对于非常简单的组件仍然可行,但您可能希望在将来对其进行更改并添加更多“类似React”的功能,如hooks。在那时,它可能会出现问题,而React通常不会告诉您这是导致应用程序出错的原因。如果发生这种情况,要找到错误可能会很头疼,特别是如果函数位于另一个文件中。

这篇文章中可以找到一个示例,说明在使用错误边界时它可能会出错。

根据这个Stack Overflow回答,以函数调用的方式可能在性能方面更快,但在我看来,在这种情况下根本不使用函数是更安全的选择。

所以,如果您认为自己足够小心,没有人会阻止您。但请确保不要自己给自己找麻烦。祝好运!

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage