0

0

react是组件化开发吗

WBOY

WBOY

发布时间:2022-04-22 10:44:26

|

1862人浏览过

|

来源于php中文网

原创

react是组件化开发;组件化是React的核心思想,可以开发出一个个独立可复用的小组件来构造应用,任何的应用都会被抽象成一颗组件树,组件化开发也就是将一个页面拆分成一个个小的功能模块,每个功能完成自己这部分独立功能。

react是组件化开发吗

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

react是组件化开发吗

react是组件化开发

1.组件化思想

  • 当人们面对复杂问题的处理方式:
    • 将复杂的问题进行拆解, 拆分成很多个可以处理的小问题
    • 将其放在整体当中,你会发现大的问题也会迎刃而解
  • 其实上面的思想就是分而治之的思想:
    • 分而治之是软件工程的重要思想,是复杂系统开发和维护的基石
    • 而前端目前的模块化和组件化都是基于分而治之的思想

    2.什么是组件化开发呢?

    • 组件化也是类似的思想:
      • 如果我们将一个页面中全部逻辑放在一起, 处理起来会变得非常复杂, 不利于后续管理及扩展
      • 但如果我们将一个页面拆分成一个个小的功能模块, 每个功能完成自己这部分独立功能, 那么整个页面的管理和维护变得非常容易

    React组件化开发

    • 我们需要通过组件化的思想来思考整个应用程序:
      • 我们将一个完整的页面分成很多个组件
      • 每个组件都用于实现页面的一个功能块

    3.React的组件化

    • 组件化是 React 的核心思想,前面我们封装的 App 本身就是一个组件
      • 组件化提供了一种抽象,让我们可以开发出一个个独立可复用的小组件来构造我们的应用
      • 任何的应用都会被抽象成一颗组件树

    • 组件化思想的应用:
      • 尽可能的将页面拆分成一个个小的、可复用的组件
      • 这样让我们的代码更加方便组织和管理,并且扩展性也更强

    4.React组件分类

    • React的组件相对于 Vue 更加的灵活和多样,按照不同的方式可以分成很多类组件:
      • 根据组件的定义方式,可以分为:函数组件(Functional Component)和类组件(Class Component)
      • 根据组件内部是否有状态需要维护,可以分成:无状态组件(Stateless Component)和有状态组件(Stateful Component)
      • 根据组件的不同职责,可以分成:展示型组件(Presentational Component)和容器型组件(Container Component)
    • 这些概念有很多重叠,但是它们最主要是关注数据逻辑UI展示的分离:
      • 函数组件、无状态组件、展示型组件主要关注UI的展示
      • 类组件、有状态组件、容器型组件主要关注数据逻辑

    React 创建组件

    1.类组件

    • 类组件的定义由如下要求:
      • 组件的名称是大写字符开头 (无论类组件还是函数组件)
      • 类组件需要继承自: React.Component
      • 类组件必须实现 render 函数
    • 使用 class 定义一个组件:
      • constructor是可选的,我们通常在 constructor 中初始化一些数据
      • this.state中维护的就是我们组件内部的数据
      • render() 方法是 class 组件中唯一必须实现的方法

    2.render函数的返回值

    render函数被调用时, 它会检查 this.propsthis.state 的变化并返回以下类型之一

    • React元素  
      • 通常通过 JSX 创建
      • 例如:

        ShopWind网店系统
        ShopWind网店系统

        ShopWind网店系统是国内最专业的网店程序之一,采用ASP语言设计开发,速度快、性能好、安全性高。ShopWind网店购物系统提供性化的后台管理界面,标准的网上商店管理模式和强大的网店软件后台管理功能。ShopWind网店系统提供了灵活强大的模板机制,内置多套免费精美模板,同时可在后台任意更换,让您即刻快速建立不同的网店外观。同时您可以对网模板自定义设计,建立个性化网店形象。ShopWind网

        下载
        会被 React 渲染为 DOM节点, \会被 React 渲染为自定义组件
      • 无论是

        还是 均为 React 元素
    • 数组或 fragments: 使得 render 方法可以返回多个元素
    • Portals: 可以渲染子节点到不同的 DOM 子树中
    • 字符串或数值类型: 他们在 DOM 中会被渲染为文本节点
    • 布尔类型或null: 什么都不渲染

    3.函数组件

    函数组件是使用 function 来进行定义的函数, 只是这个函数会返回和类组件中 render 函数一样的内容

    • 函数组件的特点 (后面会讲hooks, 就不一样了)
      • 没有生命周期, 也会被更新并挂载, 但是没有生命周期函数
      • 没有 this (组件实例)
      • 没有内部状态 (state)

    推荐学习:《react视频教程

    相关专题

    更多
    c语言中null和NULL的区别
    c语言中null和NULL的区别

    c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

    231

    2023.09.22

    java中null的用法
    java中null的用法

    在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

    435

    2024.03.01

    js 字符串转数组
    js 字符串转数组

    js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    254

    2023.08.03

    js截取字符串的方法
    js截取字符串的方法

    js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

    206

    2023.09.04

    java基础知识汇总
    java基础知识汇总

    java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

    1463

    2023.10.24

    字符串介绍
    字符串介绍

    字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

    617

    2023.11.24

    java读取文件转成字符串的方法
    java读取文件转成字符串的方法

    Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

    548

    2024.03.22

    php中定义字符串的方式
    php中定义字符串的方式

    php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

    543

    2024.04.29

    Java 桌面应用开发(JavaFX 实战)
    Java 桌面应用开发(JavaFX 实战)

    本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

    36

    2026.01.14

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    React 教程
    React 教程

    共58课时 | 3.6万人学习

    国外Web开发全栈课程全集
    国外Web开发全栈课程全集

    共12课时 | 1.0万人学习

    React核心原理新老生命周期精讲
    React核心原理新老生命周期精讲

    共12课时 | 1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号