React之JSX语法

1. JSX的介绍

  JSX(JavaScript XML)——一种在React组件内部构建标签的类XML语法。react在不使用JSX的状况下同样能够工做,然而使用JSX能够提升组件的可读性,所以推荐使用JSX。javascript

  1. 基于ECMAScript的一种新特性
  2. 一种定义带属性树结构的语法

  JSX的特性:css

这里写图片描述

  它具有如下好处:html

  1. 更加熟悉
  2. 更加语义化
  3. 更加直观
  4. 抽象化
  5. 关注分离点

2.JSX的使用

  1. React对大小写敏感,若是是自定义组件,则必须首字母大写,若是是DOM自带的标签,则要小写(好比div p span等),不然可能出错,这也是一种规范。
  2. 嵌套
  3. 求值表达式。(可使用表达式,例如’>’,’<’,三目表达式等,可是函数没法使用,例如if……else)
  4. 驼峰命名
  5. htmlFor className

这里写图片描述

为组件使用css样式:java

这里写图片描述

JSX语法只支持求值表达式,不支持函数,这里有四种条件判断的写法:react

  1. 三目运算符 
    这里写图片描述算法

  2. 使用变量,并在属性中引用 
    这里写图片描述浏览器

  3. 直接调用函数,讲逻辑转化到函数中 
    这里写图片描述安全

  4. 比较运算符(|| &&) 
    这里写图片描述babel

  还有一种万能函数表达式: 
  这里写图片描述markdown

3.非DOM属性

JSX中引入了三个非DOM属性:dangerouslySetInnerHTML、ref、key

1.dangerouslySetInnerHTML

function createMarkup() { return {__html: 'First &middot; Second'}; }; <div dangerouslySetInnerHTML={createMarkup()} />

 

在JSX中直接插入HTML代码。 
会被增长被跨站攻击的可能(XSS)

用例: 
若是是这样:

<div id="demo"></div> <script type="text/babel"> var Test = React.createClass({ getInitialState: function() { return {html: '我想让它换行显示<br />,我想让它换行显示<br />'}; }, render: function() { return ( <div>{this.state.html}</div> ); } }); ReactDOM.render( <Test />, document.getElementById('demo') ); </script>

 

浏览器将会显示: 
这里写图片描述

  咱们能够看到,React并无帮咱们将<br> 标签,解析成html,而是直接当成字符串处理,这是为了安全考虑,避免XSS攻击。 
  而若是咱们已经确保语句安全,而且想要实现将<br> 标签出来,则就须要dangerouslySetInnerHTML

<div id="demo1"></div> <script type="text/babel"> var rawHTML={ __html:"我想让它换行显示<br />,我想让它换行显示<br />" }; ReactDOM.render( <div dangerouslySetInnerHTML={rawHTML}></div>, document.getElementById('demo1') ); </script>

 

浏览器将会显示: 
这里写图片描述

  咱们能够看到,这里已是换行了,也就是说React已经将<br> 标签解析成了咱们想要的html。


2.ref

  组件并非真实的 DOM 节点,而是存在于内存之中的一种数据结构,叫作虚拟 DOM (virtual DOM)。只有当它插入文档之后,才会变成真实的 DOM 。根据 React 的设计,全部的 DOM 变更,都先在虚拟 DOM 上发生,而后再将实际发生变更的部分,反映在真实 DOM上,这种算法叫作 DOM diff ,它能够极大提升网页的性能表现。 
  可是,有时须要从组件获取真实 DOM 的节点,这时就要用到 ref 属性。

var MyComponent = React.createClass({ handleClick: function() { this.refs.myTextInput.focus(); }, render: function() { return ( <div> <input type="text" ref="myTextInput" /> <input type="button" value="Focus the text input" onClick={this.handleClick} /> </div> ); } }); ReactDOM.render( <MyComponent />, document.getElementById('example') );

 

3.key

这里写图片描述

<div id="demo3"></div> <script type="text/babel"> var UseKey=React.createClass({ render:function(){ return <ul> <li key="1">a</li> <li key="2">b</li> <li key="3">c</li> </ul> } }); ReactDOM.render( <UseKey />, document.getElementById('demo3') ); </script>

 

浏览器显示:

这里写图片描述

  注意:同一个组件以内,不能出现相同的key,列表之类的组件,最好加上key属性,能够提高性能


这里写图片描述

 

引用原文:http://blog.csdn.net/deeplies/article/details/52641073

 

写博客是为了记住本身容易忘记的东西,另外也是对本身工做的总结,文章能够转载,无需版权。但愿尽本身的努力,作到更好,你们一块儿努力进步!

若是有什么问题,欢迎你们一块儿探讨,代码若有问题,欢迎各位大神指正!

相关文章
相关标签/搜索