React组件
- 组件是
React的基石,所有的React应用程序都是基于组件的。
- 之前
React组件,使用React.createClass来进行声明
var List = React.createClass({
getInitialState: function(){
return['a','b','c']
},
render: function(){
return(...);
}
});
React官方第一时间就支持了ES6 class 的方法,这种写法可读性更强,一个直观的表现就是不用写getInitialState方法了,可以直接在constructor里面定义this.state的值。所以以后代码采用以下格式。
import React from 'react';
class List extends React.components{
constructor(){
super();
this.state = ['a','b','c'];
}
render(){
return(...);
}
}
- 这一节里测试一下
React的组件
- 在
src/js/下创建文件夹components创建一个header.js
header.js如下
import React from 'react';
import ReactDOM from 'react-dom';
export default class CompomentHeader extends React.Component{
render(){
return(
<header>
<h1>这里是表头</h1>
</header>
);
}
}
var React = require('react');
var ReactDOM = require('react-dom');
import CompomentHeader from './components/header';
class Index extends React.Component {
render() {
return (
<div>
<CompomentHeader/>
<h1>页面主题内容</h1>
</div>
);
}
}
ReactDOM.render( < Index / > , document.getElementById('example'));
HTML标签与React组件
- React可以直接渲染HTML类型的标签,也可以渲染React的组件
- HTML类型的标签第一个字母用小写来写表示。
import React from 'react';
let divElement = <div className="foo"/>;
//等同于
let divElement = React.createElement('div',{className:'foo'});
import React from 'react';
class Headline extends React.component{
...
render(){
return <h1>Hello React</h1>
}
}
let Headline = <Headline />;
let headline = React.createElement(Headline);
JSX语法使用第一个字母大小写来区分是一个普通的HTML标签还是一个React组件
- 注意:因为
JSX本身是JavaScript语法,所以一些JavaScript中的保留字要用其他的方式书写,比如第一个例子中class要写成className