首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >手动实例化ReactNative组件?

手动实例化ReactNative组件?
EN

Stack Overflow用户
提问于 2018-01-31 19:21:13
回答 1查看 659关注 0票数 0

在ReactNative中,您似乎可以做一些类似于new SomeComponent(props)return someComponent.render()的事情。我猜这基本上就是JSX在直接声明<SomeComponent someProp="etc"/>时所做的事情吧?如果是这样的话,是否有任何潜在的不利因素手动操作组件而不是使用JSX?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-01-31 19:38:06

在ReactNative中,您似乎可以执行类似于新SomeComponent(props)的操作,并返回someComponent.render()

不怎么有意思。如果手动实例化组件类,除其他外,生命周期方法(componentWillMount()componentDidMount()将无法工作。

我猜这基本上就是JSX在直接声明

看看babel编译到什么,但基本上JSX编译成普通的js:

代码语言:javascript
运行
复制
class Hello extends React.Component {
  render() {
    return <div>Hello {this.props.toWhat}</div>;
  }
}

翻译为:

代码语言:javascript
运行
复制
class Hello extends React.Component {
  render() {
    return React.createElement('div', null, `Hello ${this.props.toWhat}`);
  }
}

如果是这样的话,是否存在手动操作组件而不是使用JSX的潜在缺点?

您可以使用React.createElement,完全避免使用JSX,但在我的经验中,这更难、更详细。手动实例化组件,虽然正如您最初建议的那样,但它违背了使用React的目的:)

一些更详细的好链接:

https://reactjs.org/docs/react-without-jsx.html

https://reactjs.org/docs/react-component.html

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48549901

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档