React : 是一个用于构建用户界面的 JAVASCRIPT 库,主要用于构建UI。
实例:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>Hello React!</title>
//引入了三个库: react.min.js 、react-dom.min.js 和 babel.min.js:
<script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
<script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
<script src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"</script>
</head>
<body>
<div id="example"></div>
<script type="text/babel">
//将一个 h1 标题,插入 id="example" 节点中,可以在以下代码中嵌套多个 HTML 标签,需要使用一个 div 元素包裹它
ReactDOM.render(
<h1>Hello, world!</h1>,
document.getElementById('example') );
</script>
</body>
</html>
React.createClass 方法用于生成一个组件类 :例
var HelloMessage = React.createClass({
render: function() {
return <h1>Hello {this.props.name}</h1>; }});
ReactDOM.render( <HelloMessage name="Runoob" />,
document.getElementById('example'));
React State(状态):可变
getInitialState: function() {
return {liked: false};
},
handleClick: function(event) {({liked: !this.state.liked});
React Props:子组件只能通过 props 来传递数据。不可变
var HelloMessage = React.createClass({render: function() {
return <h1>Hello {this.props.name}</h1>; }});
ReactDOM.render( <HelloMessage name="Runoob" />,
document.getElementById('example')
React AJAX:
React 组件的数据可以通过 componentDidMount 方法中的 Ajax 来获取,当从服务端获取数据库可
以将数据存储在 state 中,再用 this.setState 方法重新渲染 UI。
var UserGist = React.createClass({getInitialState: function() {
return { username: '', lastGistUrl: '' }; },
componentDidMount: function() {
this.serverRequest = $.get(this.props.source, function (result) {
var lastGist = result[0];
this.setState({ username: lastGist.owner.login,lastGistUrl:
lastGist.html_url });
}.bind(this));
},
componentWillUnmount: function() {
this.serverRequest.abort(); },
render: function() {
return ( <div> {this.state.username} 用户最新的 Gist 共享地址:
<a href={this.state.lastGistUrl}>{this.state.lastGistUrl}</a>
</div> );
}}
);
ReactDOM.render(<UserGistsource=
"https://api.github.com/users/octocat/gists" />, mountNode);
React Refs:React 支持一种非常特殊的属性 Ref ,你可以用来绑定到 render() 输出的任何组件上。