1. super是什么
super关键字,它指代父类的实例(即父类的this对象)。子类必须在constructor方法中调用super方法,否则新建实例时会报错。这是因为子类没有自己的this对象,而是继承父类的this对象,然后对其进行加工。如果不调用super方法,子类就得不到this对象。
constructor() {
super();
this.state = {searchStr: ''};
this.handleChange = this.handleChange.bind(this);
}
React的官方例子中都是加上了 props 作为参数
constructor(props) {
super(props);
this.state = {searchStr: ''};
this.handleChange = this.handleChange.bind(this);
}
2. 加不加props的区别究竟在哪里呢?
只有一个理由需要传递props作为super()的参数,那就是你需要在构造函数内使用this.props
class Clock extends React.Component {
constructor(props) {
super(props);
this.state = {date: new Date()};
}
render() {
return (
<div>
<h1>Hello, world!</h1>
<h2>现在是 {this.state.date.toLocaleTimeString()}.</h2>
</div>
);
}
}
ReactDOM.render(
<Clock />,
document.getElementById('example')
);