React学习第二天——React组件

news2024/9/9 8:06:44

一、傻瓜组件和聪明组件

傻瓜组件也叫展示组件,负责根据props展示页面信息。

聪明组件也叫容器组件,负责数据的获取和处理。

二、函数式组件

  • 函数式组件是⼀种⽆状态组件,是为了创建纯展示组件,这种组件只负责根据传⼊的props来展示,不涉及到要state状态的操作。
  • 组件不会被实例化,整体渲染性能得到提升。
  • 组件不能访问this对象。
  • 组件⽆法访问⽣命周期的⽅法。
  • ⽆状态组件只能访问输⼊的props,同样的props会得到同样的渲染结果,不会有副作⽤。
// 这种写法是新建⼀个组件⻚⾯把组件暴露出去的写法
import React from 'react'
export default function xxx() {
 return (
   <div>
     我是函数式组件
   </div>
 )
}

// 这种写法是在⻚⾯内部创建组件不⽤给外部使⽤,只供⻚⾯内部使⽤
function xxx() {
 return (
   <div>
     我是函数式组件
   </div>
 )
}

三、class组件(不常用)

import React, { Component } from 'react'
export default class ConditionLoop extends Component {
 render() {
   return (
     <div>

     </div>
   )
 }
}

四、Purecomponent

PureComponent是内部定制了shouldComponentUpdate⽣命周期的Component,重写了⼀个⽅法来替换shouldComponentUpdate⽣命周期⽅法。

平常开发过程中设计组件能使⽤PureComponent的地⽅都尽量使⽤,使⽤PureComponent可以省去shouldComponentUpdate⽣命周期的代码,代码会简单很多。

两个小原则:

  1. 确保数据类型是值类型
  2. 如果是引⽤类型,确保地址不变,同时不应当有深层次数据变化
// 用 Purecomponent 代替生命周期
class Title extends PureComponent {
    // shouldComponentUpdate(nextProps){
    //     return nextProps.title !== this.props.title
    // }
  render() {
    console.log('title组件')
    return (
      <div>
        标题:{this.props.title}
      </div>
    )
  }
}

五、React.memo

React.memo是⼀个⾼阶组件的写法。React.memo让函数组件也拥有了PureComponent的功能。

// 使用React.memo代替以上的title组件,让函数式组件也拥有Purecomponent的功能
const Title = React.memo((props)=>{
    console.log('title组件')
    return(
        <div>
            标题:{props.title}
        </div>
    )
})

六、组件复合写法

组件复合类似于我们在vue框架⾥⾯⽤的组件插槽

import React from 'react'

function Dialog(props){
    return(
        <div style={{border:`5px solid ${props.color || "green"}`}}>
            {/* 相当于vue框架中的匿名插槽 */}
            {props.children}
            {/* 相当于vue框架中的具名插槽 */}
            {props.btn}
        </div>
    )
}

export default function Composition() {
    const confimBtn = (
        <button onClick={()=>alert('ok?')}>确认</button>
    )
  return (
    <div>
      <h1>组件复合写法</h1>
      <Dialog color='pink' btn={confimBtn}>
        <h2>小滴课堂</h2>
        <p>欢迎欢迎</p>
      </Dialog>
    </div>
  )
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1963756.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

揭秘住宅IP代理:原理、用途以及应用分析

在大数据时代&#xff0c;互联网成为我们生活与工作中不可或缺的一部分。然而&#xff0c;随着网络环境的日益复杂&#xff0c;隐私保护、网络访问限制等问题也逐渐凸显&#xff1b;以及跨境业务蓬勃发展。在这样的背景下&#xff0c;住宅IP代理作为一种技术解决方案&#xff0…

6、指针

6 指针 6.1 指针的本质&#xff08;间接访问的原理&#xff09; 指针&#xff1a;变量的地址 指针变量&#xff1a;用一个变量来存放另一个变量的地址&#xff0c;该变量即为指针变量 指针变量占内存大小&#xff0c;32位程序占4字节&#xff0c;64位占8字节 取地址操作符、取…

数据结构_study(三)

栈 先进后出&#xff0c;LIFO&#xff08;last in first out&#xff09;&#xff0c;只能在表尾做插入删除操作的线性表 栈顶&#xff1a;允许插入和删除的一端 栈底&#xff1a;最先进栈 空栈&#xff1a;没有数据元素 压栈、入栈&#xff1a;插入操作 弹栈、出栈&#xf…

ubuntu20复现NBV探索

官网代码 后退地平线下一个最佳景观规划师 这个代码有些久远&#xff0c;issue里面有人已经在ubuntu20里面使用了3dmr&#xff0c;但是他那个代码我也运行不成功&#xff0c;docker网络一直也不佳&#xff0c;所以还是自己重新修改源码靠谱。 最终实现的代码等有时间上传到gi…

Day26 | 贪心算法 134. 加油站 135. 分发糖果 860.柠檬水找零 406.根据身高重建队列

语言 Java 134. 加油站 题目链接&#xff1a;加油站 题目 在一条环路上有 n 个加油站&#xff0c;其中第 i 个加油站有汽油 gas[i] 升。 你有一辆油箱容量无限的的汽车&#xff0c;从第 i 个加油站开往第 i1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发…

【每日一题】【map和set】RC-v7 熊猫血 C++

2024 睿抗机器人开发者大赛CAIP-编程技能赛-高职组&#xff08;省赛&#xff09; RC-v7 熊猫血 题目描述 在“一年一度喜剧大赛”上有一部作品《少爷和我》&#xff0c;讲的是霸道管家龙傲天和憨厚少爷刘波的故事。管家有着霸总文学主人公所有的毛病&#xff0c;包括会咳出熊…

服务运营 | NRL:疫苗供应链优化建模:综述与未来机遇(上)

编者按&#xff1a; 本次推文将解读近期发表在Naval Research Logistics中的Optimization modeling for pandemic vaccine supply chain management: A review and future research opportunities一文。这篇文章总结与反思了大流行时期的疫苗供应链管理&#xff0c;具体包括疫…

C#基于SkiaSharp实现印章管理(5)

印章中最常见的特殊形状通常是五角星&#xff0c;空心、实心的都可能存在&#xff0c;本文学习并实现在印章内部绘制五角星形状。   百度五角星的绘制方法&#xff0c;主要分为三种&#xff1a;   1&#xff09;五角星各点坐标固定&#xff0c;直接调用编程语言的绘制线条或…

线性结构、线性表、顺序表、链表、头插法、尾插法、中间插入或删除一个节点

梳理几个名词&#xff1a; 逻辑地址&#xff1a;就是说是第几个元素。 物理地址&#xff1a;也就是存储地址&#xff0c;在计算机里具体存放的位置。 线性表的存储结构分为&#xff1a; &#xff08;1&#xff09;顺序存储结构&#xff1a;将数据依次存储在连续的整块物理空…

综合项目部署——eleme前端部署(eighteen day)

显示没有空格没有注释的内容&#xff1a; [rootstatic-server ~]# grep -Ev "#|^$" /usr/local/nginx/conf/nginx.conf 1、多虚拟主机的配置 [rootstatic-server ~]# vim /usr/local/nginx/conf/nginx.conf [rootstatic-server ~]# /usr/local/nginx/sbin/nginx #启…

如何破解绩效管理的难题?

绩效管理的核心问题 &#x1f4bc; 在现代企业运营中&#xff0c;绩效管理一直被视为提升工作效率和实现公司战略目标的重要手段。然而&#xff0c;实际操作中&#xff0c;我们经常会遇到一系列棘手的问题&#xff0c;这些问题不仅影响了绩效管理的有效性&#xff0c;还常常让…

winform程序中拷贝文件夹最快速方法

1、先将一个项目的文件夹拷贝到另一个项目的目录下 下图将ParameterSetting文件夹拷贝到Datalib文件夹下 2、直接复制该文件&#xff0c;然后到vs界面去粘贴 复制ParameterSetting文件夹&#xff0c;然后在Datalib项目这里鼠标右键单击&#xff0c;然后点击“粘贴”&#xff0…

机器学习(五) -- 无监督学习(2) --降维2

系列文章目录及链接 上篇&#xff1a;机器学习&#xff08;五&#xff09; -- 无监督学习&#xff08;2&#xff09; --降维1 下篇&#xff1a; 前言 tips&#xff1a;标题前有“***”的内容为补充内容&#xff0c;是给好奇心重的宝宝看的&#xff0c;可自行跳过。文章内容被…

《动手做科研》06. 如何产生新的研究想法

地址链接:《动手做科研》06. 如何产生新的研究想法 欢迎加入我的知识星球&#xff0c;定期分享AI论文干货知识&#xff01; 导读: 提出好的研究想法是相当困难的&#xff0c;特别是当你刚接触一个领域时——这需要对文献中的空白有所了解。然而&#xff0c;产生研究想法的过程可…

数学建模--智能算法之模拟退火算法

目录 算法原理 应用场景 实现方法 代码示例&#xff1a; MATLAB&#xff1a; Python&#xff1a; 总结 模拟退火算法在数学建模中的具体应用案例有哪些&#xff1f; 如何选择模拟退火算法的参数&#xff08;如初始温度、冷却率等&#xff09;以优化求解过程&#xff1…

根据json构建uml类图代码工具实现

文章目录 1.UML简介1.1 什么是UML建模1.2 使用UML建模的好处 2.当前UML在研发场景下痛点3.UML工具的优化实现3.1 json结构设计3.2 json类图解析器实现3.3 在线uml类图渲染实现3.3.1 前端渲染页面3.3.2 后端数据接口 3.4 在线渲染效果 4. 总结 【摘要】本文介绍UML基本概念及相关…

Linux中安装C#的.net,创建运行后端或控制台项目

安装脚本命令&#xff1a; 创建一个sh文件并将该文件更改权限运行 sudo apt update wget https://packages.microsoft.com/config/ubuntu/20.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb sudo dpkg -i packages-microsoft-prod.deb sudo apt-get upd…

科普文:Spring Cloud Alibaba在GraalVM上的性能测试

GraalVM 介绍 GraalVM概述 - Spring Cloud Alibaba官网 科普文&#xff1a;GraalVM简介-CSDN博客 科普文&#xff1a;OpenJDK vs. GraalVM vs. Amazon Corretto性能测试-CSDN博客 科普文&#xff1a;【方向盘】OpenJDK生态圈-CSDN博客 科普文&#xff1a;Oracle JDK收费后…

【32单片机篇】项目:实时时钟

一、项目需求 1. OLED屏幕显示当前时间、日期、闹钟等信息&#xff1b; 2. 正常模式下&#xff0c;按下 KEY1 &#xff0c;进入时间设置模式&#xff0c;此时按下 KEY2 则可以循环跳转修改秒、分、时、日、月、年&#xff1b; 3. 时间设置模式下&#xff0c;KEY3 增加数值&…

【Redis】如何利用 Redis 实现一个分布式锁?

&#x1f44f;大家好&#xff01;我是和风coding&#xff0c;希望我的文章能给你带来帮助&#xff01; &#x1f525;如果感觉博主的文章还不错的话&#xff0c;请&#x1f44d;三连支持&#x1f44d;一下博主哦 &#x1f4dd;点击 我的主页 还可以看到和风的其他内容噢&#x…