知识点
1、html模板3个预加载的js文件,script的type属性
2、ReactDOM.render()
3、JSX语言:允许js和html的混写
4、component组件:React.createClass({})
5、this.props属性
6、PropTypes组件类的验证属性
7、虚拟dom节点:DOM diff算法 ,它可以极大提高网页的性能表现
8、this.state:将组件看成是一个状态机
9、表单
10、生命周期
11、Ajax:componentDidMount方法
优点
1、React速度很快:它并不直接对DOM进行操作,引入了一个叫做虚拟DOM的概念,安插在javascript逻辑和实际的DOM之间,性能好。
2、跨浏览器兼容:虚拟DOM帮助我们解决了跨浏览器问题,它为我们提供了标准化的API,甚至在IE8中都是没问题的。
3、一切都是component:代码更加模块化,重用代码更容易,可维护性高。
4、单向数据流:Flux是一个用于在JavaScript应用中创建单向数据层的架构,它随着React视图库的开发而被Facebook概念化。
5、同构、纯粹的javascript:因为搜索引擎的爬虫程序依赖的是服务端响应而不是JavaScript的执行,预渲染你的应用有助于搜索引擎优化。
6、兼容性好:比如使用RequireJS来加载和打包,而Browserify和Webpack适用于构建大型应用。它们使得那些艰难的任务不再让人望而生畏。
缺点
1、React本身只是一个V而已,并不是一个完整的框架,所以如果是大型项目想要一套完整的框架的话,基本都需要加上ReactRouter和Flux才能写大型应用。
2、大多数坑没踩出来。。。。。
大概就是现在还太新了很难说将来有没有大的API变化,目前在大的稳定的项目上采用React的,我也就只知道有Yahoo的Email。
所以现在很少有批评React的声音,也许不是他真的就没有坑,而是那些坑还没有被踩出来而已。
参考文献:
http://blog.csdn.net/oyuemijindu/article/details/51222884