组件
组件是
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.jsheader.js如下
import React from 'react';
import ReactDOM from 'react-dom';
export default class CompomentHeader extends React.Component{
render(){
return(
<header>
<h1>这里是表头</h1>
</header>
);
}
}index.js如下
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';
//当一个标签里面为空的时候,可以直接使用自闭和标签
//注意class是一个JavaScript保留字,所以如果class应该替换成className
let divElement = <div className="foo"/>;
//等同于
let divElement = React.createElement('div',{className:'foo'});React组件标签第一个字母大写。
import React from 'react';
class Headline extends React.component{
...
render(){
//直接return JSX语法
return <h1>Hello React</h1>
}
}
let Headline = <Headline />;
let headline = React.createElement(Headline);JSX语法使用第一个字母大小写来区分是一个普通的HTML标签还是一个React组件注意:因为
JSX本身是JavaScript语法,所以一些JavaScript中的保留字要用其他的方式书写,比如第一个例子中class要写成className
最后更新于
这有帮助吗?