React简谈
2016-06-12 13:23
393 查看
这段时间学习了react.js,在此做个总结。
react.js在优势上我认为是两个大点,第一是性能,作者从dom操作实际出发,通过虚拟dom(这里虚拟dom实际上是以jsx格式的语法来预先构建dom结构再通过浏览器或者服务器端渲染成html dom元素)实现的。react注意到影响页面性能很大程度上是dom操作的原因,因此它提供有辨识机制的dom更新策略,按需更新,性能大大提高。
第二个点是组件化便利,看下面这段代码:
React.createClass()创建了一个组件对象被赋在变量NewEle上,这里NewEle充当自定义的元素标签可以被以组件形式渲染到真实dom中。过程很简便,每个标签都是一个独立的组件,这样对于构建dom结构有低耦合,易堆用的优势。写react顺手后你只会注意到自己在写组件,而很少去关注单个的元素。这点是react很大的优势的地方。
React的缺点就是它长得有点另类,jsx语法有别于js语法,需要时间去熟悉。专注于view层构建的它需要其他的架构如flux来搭建MVC的开发模式。
react.js在优势上我认为是两个大点,第一是性能,作者从dom操作实际出发,通过虚拟dom(这里虚拟dom实际上是以jsx格式的语法来预先构建dom结构再通过浏览器或者服务器端渲染成html dom元素)实现的。react注意到影响页面性能很大程度上是dom操作的原因,因此它提供有辨识机制的dom更新策略,按需更新,性能大大提高。
第二个点是组件化便利,看下面这段代码:
var Input=React.createClass({ getInitialState:function(){ return{value:"请输入..."}; }, handelClick:function(){ this.setState({ value:"请再输入", }); }, render:function(){ return ( <div> <input type="text" className="a1" placeholder={this.state.value} onChange={this.handelClick}/> </div> ); } }); ReactDOM.render( <Input/>, document.getElementById("exm") );
React.createClass()创建了一个组件对象被赋在变量NewEle上,这里NewEle充当自定义的元素标签可以被以组件形式渲染到真实dom中。过程很简便,每个标签都是一个独立的组件,这样对于构建dom结构有低耦合,易堆用的优势。写react顺手后你只会注意到自己在写组件,而很少去关注单个的元素。这点是react很大的优势的地方。
React的缺点就是它长得有点另类,jsx语法有别于js语法,需要时间去熟悉。专注于view层构建的它需要其他的架构如flux来搭建MVC的开发模式。
相关文章推荐
- React Native笔记
- React.js学习
- 使用Webpack构建React应用
- React.js学习之理解JSX和组件
- IOS ReactiveCoCoa初学总结
- ReactJs笔记
- React.js学习之环境搭建
- React.js学习之环境搭建
- Sublime Text 3 搭建 React.js 开发环境
- reactor 类库,基于事件编程
- 优购微零售-已上线项目中,完全使用react-native的一些体会
- react-native DatePicker日期选择组件的实现
- react-native DatePicker日期选择组件的实现
- React和Redux的连接react-redux
- React Native运行官方例子----组件集合
- React Router context.router 未定义错误
- React官网学习笔记
- [前端框架]React
- Reactjs 入门基础(三)
- React Native Android增加本地图片