程序员

React组件理解

2020-07-01  本文已影响0人  shandamengcheng

什么是组件

组件允许我们将应用的UI拆分成独立的、可复用的模块,其实也就是可复用的代码片段。React应用程序就是由组件来构建的,也就是说React应用的基石!

image

React中的组件类别

class组件

这个组件主要是ES6中的写法。我们的一个class组件的基本结构如下:

class MyComponent extends React.Component {

constructor(props) {

super(props)

}

render () {

return (<div>React</div>)

}

}

函数组件

函数组件就像对简单了,形式如下:

function MyComponent (props) {

return <div>React</div>

}

组件的通性:

组件的调用

每次我们引用一个组件时,比如:

return <MyComponent />

这种形式,那么会做什么操作呢?

现在先简单了解一下:

会找到相应的组件,如果为函数组件直接调用,这时候会返回React元素。如果为class组件,会创建一个该组件的一个实例(等价于ES6中的 new MyComponent())

有状态组件和无状态组件

状态,简单理解就是数据的另一种称呼。在react组件中,状态为state。状态只会存在于class组件中,函数组件是没有状态的。对于class组件,先前说了,constructor函数可以省略。当有状态时,其是不可以省略的。

class MyComponent extends React.Component {

constructor(props) {

super(props);

this.state = {

}

}

render () {

return ....

}

}

如上所示,this.state即为定义的状态。

为什么使用state

为什么在constructor中使用this.state

因为组件是复用的,上面也说到了,每次调用class组件时,其实就是创建了一个实例,那么既然我想在每个组件中用到我的state,那么把这个state定义到this上是必然的。

上一篇 下一篇

猜你喜欢

热点阅读