React文档(二十)不使用JSX

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了React文档(二十)不使用JSX相关的知识,希望对你有一定的参考价值。

JSX并不是使用React的一个强制需求。当你不需要在你的构造环境里设置编译那么不使用JSX会很方便。

每一个JSX元素只是调用React.createElement(componnet, props, ...children)的语法糖。因此,JSX能做的事原生js同样也做得到。

举个例子,下面的代码用JSX:

class Hello extends React.Component {
  render() {
    return <div>Hello {this.props.toWhat}</div>;
  }
}

ReactDOM.render(
  <Hello toWhat="World" />,
  document.getElementById(‘root‘)
);
如果不使用JSX可以被编译成这样的代码:
class Hello extends React.Component {
  render() {
    return React.createElement(‘div‘, null, `Hello ${this.props.toWhat}`);
  }
}

ReactDOM.render(
  React.createElement(Hello, {toWhat: ‘World‘}, null),
  document.getElementById(‘root‘)
);

如果你好奇想看更多的例子JSX被转变成js,你可以试一试在线Babel编译器

组件要么被提供为一个字符串,要么是一个React.Component子类,要么是一个无状态组件的函数。

如果你已经厌倦了React.createElement方法,一个普通模式是使用简写:

const e = React.createElement;

ReactDOM.render(
  e(‘div‘, null, ‘Hello World‘),
  document.getElementById(‘root‘)
);

如果你对React.createElement使用这种简写,那么在不使用JSX语法也一样方便。

以上是关于React文档(二十)不使用JSX的主要内容,如果未能解决你的问题,请参考以下文章

React翻译官网文档之JSX

React文档介绍JSX

React文档(二十二)context

安装 Babel 以与 React 和 JSX 一起使用

关于react16.4

假如React没了JSX