美文网首页程序员
React组件理解

React组件理解

作者: shandamengcheng | 来源:发表于2020-07-01 00:16 被阅读0次

什么是组件

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

image

React中的组件类别

  • class组件

  • 函数组件

class组件

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

class MyComponent extends React.Component {

constructor(props) {

super(props)

}

render () {

return (<div>React</div>)

}

}

  • 这里要注意,constructor函数是可选的,当你没有state时,即没有该组件内部需要使用的自己的数据时,constructor函数可以省略。但是render函数一定不能省略,且render函数内部要通过return 返回一个React组件 或者是 null.

  • 第二点要注意的是,对于ES6中的class,当使用constructor函数时,内部要调用super()函数。

  • 第三点,我们发现class 继承了React.Component,那么这个React.Component是每一个React组件都会用到的一些函数,属性等的一个抽象提取。继承的思想中,父组件的作用不正是要给子组件们提供他们均可访问的属性和方法吗!

函数组件

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

function MyComponent (props) {

return <div>React</div>

}

组件的通性:

  • React中要求自定义组件名一定要以大写字母开头,这是为了区别原生HTML标签和自定义组件。如果以小写字母引用自定义组件的话,那么会出错,会因为把自定义组件解析为HTML标签而出错。

  • 两种组件都接受一个参数:props .这是因为我们在调用组件时,可以对组件进行数据传递,上层组件传递过来的数据可以通过props来进行获取访问。

组件的调用

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

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

  • react中的组件是一个可服用的具有一定功能的代码块。那么,他就会有一定的处理逻辑,比如说,在一个定义的组件中可能会进行数据的请求,处理等操作,这个时候我们就要对这些数据进行保存。因此,引入了一个state对象来保存所有的数据。这样的话,就不用一次性声明多个变量了,既方便管理,又方便操作。

    其实,在javascript good parts 一书中,道格拉斯也推荐,当你的全局变量过多时,可以通过创建对象字面量的形式来管理数据。这样的话,你的全局变量就会减少很多。

为什么在constructor中使用this.state

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

相关文章

  • RN原始项目-HelloWorld

    React Native看起来很像React,只不过其基础组件是原生组件而非web组件,。要理解React Nat...

  • React Native - 01 - Hello World!

    React Native就像React,但它使用本地组件而不是Web组件作为构建块。因此,要理解React Nat...

  • React组件理解

    什么是组件 组件允许我们将应用的UI拆分成独立的、可复用的模块,其实也就是可复用的代码片段。React应用程序就是...

  • React基础

    React包含react元素和react组件 react元素 react组件 react组件分为函数组件和类组件 ...

  • 组件复用之高阶组件(Higher Order Component

    高阶组件(HOC)是一个函数返回一个React组件,指的就是一个React组包裹着另一个React组件。可以理解为...

  • react组件

    第二单元(react的组件-state-props-setState) 课程目标 组件的基本介绍 理解组件和组件的...

  • (React启蒙)理解React组件

    本文将首先讲述如何通过React nodes创建基础的React组件,然后进一步剖析React组件内部的点滴,包括...

  • react 子组件调用父组件方法

    史上最简单易理解的 React 子组件调用父组件方法 我们只要记住 父组件通过 isShow={this.hide...

  • React组件生命周期

    问题 理解React组件的生命周期 知识点 React流程状态图 注意:流程状态图为使用React.createC...

  • react 生命周期

    React 生命周期文档 1、理解 组件对象从创建到死亡它会经历特定的生命周期阶段 React组件对象包含一系列的...

网友评论

    本文标题:React组件理解

    本文链接:https://www.haomeiwen.com/subject/fwjqqktx.html