react学习笔记
首先介绍一个fb家的快速开发react的工具 create-react-app
这个东西依赖node6.0或者更高版本。
关于在ubuntu 14.04上安装node ,可以参考这个链接
发现执行nvm install 6.0会没有任何相应...但是实际上已经安装好了。
接下来安装create-react-app
命令是: npm install --global create-react-app
然后创建一个react app
命令为:create-react-app first_react_app
挂着代理大概需要半小时左右。
或者可以使用淘宝npm镜像:
设置方法为:npm config set registry https://registry.npm.taobao.org
,设置完成后,重新执行create-react-app first-app
实现的第一个组件,功能是点击按钮增加计数...
import React, { Component } from 'react';
class ClickCounter extends Component{
constructor(props){
super(props);
this.onClickButton = this.onClickButton.bind(this);
this.state = {count:0};
}
onClickButton(){
this.setState({count: this.state.count+1});
}
render(){
return(
<div>
<button onClick={this.onClickButton}>Who am I?</button>
<div>
click Count: {this.state.count}
</div>
</div>
)
}
}
export default ClickCounter;
JSX是JS的语法扩展。JSX中使用的元素包含html中的元素和React中的组件。React 判断一个元素是 HTML 元素还是 React 组件的原则就是看第一个字母是否大 写。
React设计上的分离是逻辑上的分离,而不是技术上的分离。如果是要实现一件事,就会把CSS,html,JS三种语言混在一起。
React的数据分为prop(property)和state两种。区别是:
* prop 用于定义外部接口, state 用于记录内部状态;
* prop 的赋值在外部世界使用组件时, state 的赋值在组件内部;
* 组件不应该改变 prop 的值,而 state 存在的目的就是让组件来改变的
扩展属性:
function App1() {
return <Greeting firstName="Ben" lastName="Hector" />;
}
function App2() {
const props = {firstName: 'Ben', lastName: 'Hector'};
return <Greeting {...props} />;
}
参考资料: