广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >react三种定义组件方法是什么
  • 948
分享到

react三种定义组件方法是什么

2024-04-02 19:04:59 948人浏览 薄情痞子
摘要

这篇文章主要介绍“React三种定义组件方法是什么”,在日常操作中,相信很多人在react三种定义组件方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react三种定

这篇文章主要介绍“React三种定义组件方法是什么”,在日常操作中,相信很多人在react三种定义组件方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react三种定义组件方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

区别:1、函数式定义无状态组件不能访问生命周期方法,而es5和es6的方法定义的是有状态的组件并且可以访问生命周期方法;2、es5方法中的函数this可以自动绑定,而es6方法中的函数this不能自动绑定,需要手动绑定。

教程操作环境:windows10系统、react17.0.1版、Dell G3电脑。

react三种定义组件方法有什么区别

React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归;具体的三种方式:

  • 函数式定义的无状态组件

  • es5原生方式React.createClass定义的组件

  • es6形式的extends React.Component定义的组件

1、无状态函数式组件

它是为了创建纯展示组件,这种组件只负责根据传入的props来展示,不涉及到state状态的操作

组件不会被实例化,整体渲染性能得到提升,不能访问this对象,不能访问生命周期的方法

2、ES5 原生方式 React.createClass // RFC

React.createClass会自绑定函数方法,导致不必要的性能开销,增加代码过时的可能性。

3、E6继承形式 React.Component // RCC

目前极为推荐的创建有状态组件的方式,最终会取代React.createClass形式;相对于 React.createClass可以更好实现代码复用。

无状态组件相对于于后二者的区别

与无状态组件相比,React.createClass和React.Component都是创建有状态的组件,这些组件是要被实例化的,并且可以访问组件的生命周期方法。

React.createClass****与React.Component区别

函数this自绑定

React.createClass创建的组件,其每一个成员函数的this都有React自动绑定,函数中的this会被正确设置。

React.Component创建的组件,其成员函数不会自动绑定this,需要开发者手动绑定,否则this不能获取当前组件实例对象。

组件属性类型propTypes及其默认props属性defaultProps配置不同

React.createClass在创建组件时,有关组件props的属性类型及组件默认的属性会作为组件实例的属性来配置,其中defaultProps是使用getDefaultProps的方法来获取默认组件属性的

React.Component在创建组件时配置这两个对应信息时,他们是作为组件类的属性,不是组件实例的属性,也就是所谓的类的静态属性来配置的。

组件初始状态state的配置不同

React.createClass创建的组件,其状态state是通过getInitialState方法来配置组件相关的状态;

React.Component创建的组件,其状态state是在constructor中像初始化组件属性一样声明的。

最后总结

只要有可能,尽量使用无状态组件创建形式。

能用React.Component创建的组件的就尽量不用React.createClass形式创建组件,以增强复用性和提高性能。

到此,关于“react三种定义组件方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: react三种定义组件方法是什么

本文链接: https://www.lsjlt.com/news/97591.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • react三种定义组件方法是什么
    这篇文章主要介绍“react三种定义组件方法是什么”,在日常操作中,相信很多人在react三种定义组件方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react三种定...
    99+
    2022-10-19
  • React组件的三种写法是什么
    这篇文章将为大家详细讲解有关React组件的三种写法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。React 专注于 view 层,组件化则是 React 的基础,...
    99+
    2022-10-19
  • vue中自定义组件双向绑定的三种方法总结
    目录1. 父组件使用v-model绑定2. 父组件使用v-model绑定3. 父组件使用:name.sync绑定官方文档地址 1. 父组件使用v-model绑定 子组件props接收...
    99+
    2022-11-13
  • React组件间通信的三种方法(简单易用)
    目录一、父子组件通信二、跨级组件通信1、逐层传值2、跨级传值三、兄弟(无嵌套)组件通信四、路由传值五、Redux  React知识中一个主要内容便是组件之间的通信,以下列举...
    99+
    2022-11-12
  • Android自定义组件:1、什么是自定义组件、自定义组件的方式、定义自定义属性
    声明:本教程不收取任何费用,欢迎转载,尊重作者劳动成果,不得用于商业用途,侵权必究!!! 目录 一、前言 二、什么是自定义组件 三、自定义组件的方式 1、组合现有组件 2、在某...
    99+
    2022-06-06
    属性 自定义属性 Android
  • React中事件绑定this指向三种方法的实现
    1.箭头函数 1.利用箭头函数自身不绑定this的特点; 2.render()方法中的this为组件实例,可以获取到setState(); class App extends ...
    99+
    2022-11-12
  • vue自定义动态组件的方法是什么
    本篇内容主要讲解“vue自定义动态组件的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue自定义动态组件的方法是什么”吧! Vue.extend 思路就是拿到组件...
    99+
    2023-07-04
  • React Native自定义标题栏组件的实现方法
    大家好,今天讲一下如何实现自定义标题栏组件,我们都知道RN有一个优点就是可以组件化,在需要使用该组件的地方直接引用并传递一些参数就可以了,这种方式确实提高了开发效率。标题栏是大多数应用界面必不可少的一部分,将标题栏剥离出来做成一个组件很有必...
    99+
    2023-05-31
    react native 标题栏
  • css的三种定位方式是什么
    本篇文章为大家展示了css的三种定位方式是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。css的三种定位方式是:1、相对定位,元素的位置相对于它的原始位置计算而...
    99+
    2022-10-19
  • php遍历一个数组的三种方法是什么
    3种遍历数组的方法:1、用for语句遍历,语法“for($i=0;$i<数组长度;$i++){//循环代码}”;2、用foreach语句遍历,语法“foreach($arr as $k=>$v){//循环代码}”;3、用whil...
    99+
    2022-09-06
  • Android 自定义弹性ListView控件实例代码(三种方法)
    关于在Android中实现ListView的弹性效果,有很多不同的方法,网上一搜,也有很多,下面贴出在项目中经常用到的两种实现ListView弹性效果的方法(基本上拿来就可以用...
    99+
    2022-06-06
    自定义 方法 listview Android
  • java动态数组定义的方法是什么
    在Java中,可以使用以下两种方法定义动态数组:1. 使用ArrayList类:ArrayList是Java中提供的一个动态数组类,...
    99+
    2023-10-20
    java
  • java双重数组定义的方法是什么
    在Java中,可以使用两种方法来定义双重数组:1. 声明并初始化一个双重数组:```int[][] array = {{1, 2, ...
    99+
    2023-09-27
    java
  • react结合typescript封装组件的方法是什么
    今天小编给大家分享一下react结合typescript封装组件的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。项...
    99+
    2023-07-06
  • mfc自定义控件的方法是什么
    MFC(Microsoft Foundation Class)是一种用于开发Windows桌面应用程序的C++框架。MFC提供了一组...
    99+
    2023-09-07
    mfc
  • android自定义控件的方法是什么
    Android自定义控件的方法有以下几种:1. 继承系统控件:可以通过继承系统控件来进行扩展和定制。通过重写控件的绘制方法,修改控件...
    99+
    2023-08-16
    android
  • php的三种命名方法是什么
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php的三种命名方法一、小驼峰命名法:小驼峰法(camel方法)变量一般用小驼峰法标识。第一个单词以小写字母开始;第二个单词的首字母大写或每一个单词的首字母都采用大写字...
    99+
    2020-12-09
    php 命名方法
  • 基于React封装一个组件的方法是什么
    这篇文章主要讲解了“基于React封装一个组件的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于React封装一个组件的方法是什么”吧!antd 是如何封装组件的仓库地址divi...
    99+
    2023-06-29
  • java中二维数组的定义方法是什么
    在Java中,二维数组的定义方法如下:1. 声明一个二维数组变量:```javaint[][] arr;```2. 创建一个二维数组...
    99+
    2023-08-25
    java
  • Python元组的定义及使用方法是什么
    本篇内容主要讲解“Python元组的定义及使用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python元组的定义及使用方法是什么”吧!1、前言在Python中元组是一个和列表非常类似...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作