react-jsx

使用React,不一定非要使用JSX语法,可以使用原生的JS进行开发。但是JSX在定义类似HTML这种树形结构时,十分的简单明了。简明的代码结构更利于开发和维护。
从本质上讲,JSX 只是为 React.createElement(component, props, ...children) 函数提供的语法糖。

  • jsx代码

  Click Me

  • 编译为
React.createElement(
  MyButton,
  {color: 'blue', shadowSize: 2},
  'Click Me'
)

这很像vue里面的render函数

  • 如果不存在子节点,你可以使用自闭合(self-closing)格式的标签。例如:
  • 编译为:
React.createElement(
  'div',
  {className: 'sidebar'},
  null
)
  • jsx代码
React.render(
    
content
, document.getElementById('example') );
  • 编译为
React.render(
    React.createElement('div', null,
        React.createElement('div', null,
            React.createElement('div', null, 'content')
        )
    ),
    document.getElementById('example')
);

HTML属性

注意:标签的属性class和for,需要写成className和htmlFor。因为两个属性是JavaScript的保留字和关键字。无论你是否使用JSX。

#使用JSX
React.render(
    ,
    document.getElementById('example')
);

#不使用JSX
React.render(
    React.createElement('label', {className: 'xxx', htmlFor: 'input'}, 'content'),
    document.getElementById('example')
);

转化

  • JS表达式

表达式用{}包起来,不要加引号,加引号就会被当成字符串。
JSX是HTML和JavaScript混写的语法,当遇到<,JSX就当HTML解析,遇到{就当JavaScript解析。

  • 解析变量
var str="hello"
React.render(
    
{str}
, document.body ); //甚至 var arr=[1,2,3,4] React.render(
    {arr.map(function(item){ return
  • {item}
  • })}
, document.body );
  • 属性表达式
React.render(
    
1 ? 'class-a' : 'class-b'}>content
, document.body );
  • 子表达式
var Nav = React.createClass({
    render: function () {
        return 
nav
} }); React.render(
{2 > 1 ?
, document.body );

特别注意

  • style属性

在React中写行内样式时,要这样写,不能采用引号的书写方式

React.render(
    
xxxxx
, document.body );
  • HTML转义

比如我们有一些内容是用户输入的富文本,从后台取到数据后展示在页面上,希望展示相应的样式

var content='content';

React.render(
    
{content}
, document.body );

结果页面直接输出内容了:


A.png

React默认会进行HTML的转义,避免XSS攻击,如果要不转义,可以这么写:

var content='content';    

React.render(
    
, document.body );
  • 自定义HTML属性

如果在编写React过程中使用了自定义属性,React不会渲染的

React.render(
    
content
, document.body );
react-jsx_第1张图片
B.png

要想使用得这么写:

React.render(
    
content
, document.body );

jsx基本使用先到这里,希望可以帮到同学们

你可能感兴趣的:(react-jsx)