react2:children属性 - props进阶 - 生命周期

news2025/1/11 2:39:13

children属性:父想给子组件传递内容,都需要通过children占位

 children属性:类似vue中的slot效果

 

props 类型验证 :现在都是 typescript 替代了

ref 放普通标签上可以获取dom节点

 ref 放组件上获取组件实例,可以调用组件实例的方法. 调用:this.refs.ref在组件上的属性名.组件内方法名

    // ref放在普通标签上,获取的是dom节点

    // ref放在组件身上,获取的是组件实例

    // this.refs.Dialog //获取组件实例

    this.refs.dialog.show() //获取组件方法show()让隐藏的dialog提示框显示

dialog提示框功能 ref使用:

父:

import './App.scss'
// react应用的组件有两种创建方式:函数式组件,类组件
// rcc创建class组件
// rsf创建函数式组件
import React, { Component } from 'react';
import Child from './components/Child';
import Dialog from './components/Dialog';
import Cate from './components/Cate'

class App extends Component {
  handleClick(){
    // ref放在普通标签上,获取的是dom节点
    // ref放在组件身上,获取的是组件实例

    // this.refs.Dialog //获取组件实例
    this.refs.dialog.show() //获取组件方法
  }
  render() {
    return (
      <div>
        <Child id="1001" url="http://xxx.com">
          我是child组件里的内容会传递给子组件
        </Child>

        {/* 提示框 */}
        <button onClick={()=>{this.handleClick()}}>点击弹框</button>
        <Dialog ref='dialog'>
            <input type="text" placeholder='输入密码' />
        </Dialog>

        {/* 列表 */}
        <Cate></Cate>
      </div>
    );
  }
}

export default App;

 子

import React, { Component } from 'react';
import './Dialog.scss'
class Dialog extends Component {
    constructor(props){
        super(props);
        this.state = {
            isvisible:false //控制dialog对话框的显示隐藏
        }
    }
    show(){
        this.setState({isvisible:true})
    }
    hide = ()=>{
        this.setState({isvisible:false})
    }
    // hide(){
    //     this.setState({isvisible:false})
    // }
    render() {
        return (
            this.state.isvisible &&
            <div className='dialog'>
                <div className='content'>
                    <div className='title'>警告</div>
                    <div className='text'>
                        {/* 警告的内容,父传进来 */}
                    </div>
                    <div className='btns'>
                        <span onClick={()=>{this.hide()}}>确定</span>
                        <span onClick={()=>{this.hide()}}>取消</span>
                    </div>
                </div>
            </div>
        );
    }
}

export default Dialog;

子样式

.dialog{
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: rgb(0,0,0,0.5);

    display: flex;
    justify-content: center;
    align-items: center;
    .content{
        background-color: white;
        padding: 30px;
        min-width: 200px;
        border-radius: 10px;
        text-align: center;
        line-height: 40px;
        .title{
            font-weight: bold;
        }
        span{
            border: 1px solid greenyellow;
        }
    }
}

分类页面功能:{} 中有标签就要写

import React, { Component } from 'react';
import './Cate.scss'
class Cate extends Component {
    constructor(props){
        super(props)
        this.state = {
            catelist:[
                {text:'手机', children:[{text:'苹果手机'}, {text:'小米手机'}]},
                {text:'电脑', children:[{text:'苹果电脑'}, {text:'小米电脑'}]},
                {text:'平板', children:[{text:'苹果平板'}, {text:'小米平板'}]},
            ],
            currentIndex:0,
        }
    }
    handleClick(index){
        this.setState({currentIndex:index})
    }
    render() {
        return (
            <div className='catelist'>
                <div className='left'>
                    {
                        this.state.catelist.map((item,index) => {
                            return (
                                // active添加与否
                                <div className={`item ${this.state.currentIndex == index? 'active':''}`} onClick={()=>{this.handleClick(index)}} key={index}>
                                    {item.text}
                                </div>
                            )
                        })
                    }
                </div>
                <div className='right'>
                    {
                       this.state.catelist[this.state.currentIndex].children.map((item,index) => {
                            return(
                                <div className='item' key={index}>
                                    {item.text}
                                </div>
                            )
                        })
                    }
                </div>
            </div>
        );
    }
}

export default Cate;

sass: scss

.catelist{
    display: flex;
    .left{
        width: 100px;
        line-height: 40px;
        text-align: center;
        .item{
            border-left: 2px solid transparent;
        }
        .item.active{
            color: royalblue;
            border-left: 2px solid turquoise;
        }
    }
}

类型验证,默认值

生命周期:render在组件挂载之前执行。render是渲染组件,必须在完成后挂载(组件初次渲染)组件初次渲染和后续的每次更新都会执行

1.实例化期

2.更新期(存在期)

3.销毁器

will:将要

did:完成

show应当

 

性能优化:::

shouldComponentUpdate(nextProps, nextState)

  • nextProps: 表示下一个props。
  • nextState: 表示下一个state的值。
  • 该周期函数发生在视图将要更新前,并且可以让我们自己决定视图是否要真的更新,

    初次渲染的时候,不会调用该函数;我们可以通过在该函数的末尾返回布尔类型的值来决定是否需要重新渲染,如果返回 true,那就正常渲染,如果返回 false,那么就不渲染并且会,直接跳过 render,componentWillUpdate 以及 componentDidUpdate 阶段;并且该周期函数会接收 新的属性(nextProps)和新的状态(nextState)作为参数;

  •     // 更新期
        shouldComponentUpdate(nextProps, nextState){
            // nextProps 最新的props对象,this.props 之前的props对象
            // nextState 最新的state对象,this.state 之前的state对象
            console.log('子组件: shouldComponentUpdate');
            // 子组件发生变化
            if (JSON.stringify(nextProps) == JSON.stringify(this.props)) {
                console.log(1);
                return false
            }else{
                console.log(2);
                return true //返回true组件将继续更新,返回false组件停止更新
            }
        }
import React, { Component } from 'react';

class Child extends Component {
    // 实例化期
    constructor(props){
        super(props);
        console.log('child constructor');
    }
    componentWillMount(){
        // 组件将挂载
    }
    componentDidMount(){
        // 组件完成挂载
        // 一般在这里发请求,创建定时器,监听事件,这些操作都可能会导致内存泄漏
        console.log('componentDidMount');
    }
    // 更新期
    shouldComponentUpdate(nextProps, nextState){
        // nextProps 最新的props对象,this.props 之前的props对象
        // nextState 最新的state对象,this.state 之前的state对象
        console.log('子组件: shouldComponentUpdate');
        // 子组件发生变化,比如没了,那就不让
        if (JSON.stringify(nextProps) == JSON.stringify(this.props)) {
            console.log(1);
            return false
        }else{
            console.log(2);
            return true //返回true组件将继续更新,返回false组件停止更新
        }
    }
    componentWillUpdate(){
        // 组件将更新
    }
    componentDidUpdate(){
        // 组件完成更新
    }
    // 卸载期
    componentWillUnmount(){
        // 一般在这里取消
    }
    render() {
        console.log('child render');
        return (
            <div className='child'>
                我是Child组件
            </div>
        );
    }
}

export default Child;

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

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

相关文章

「C/C++」C/C++内存四大分区

博客主页&#xff1a;何曾参静谧的博客 文章专栏&#xff1a;「C/C」C/C学习 目录术语一、文本区&#xff08;Text Segment&#xff09;/ 代码区二、数据区&#xff08;Data Segment&#xff09;/ 全局区三、栈区&#xff08;Stack Segment&#xff09;四、堆区&#xff08;Hea…

Redis应用问题解决

16. Redis应用问题解决 16.1 缓存穿透 16.1.1 问题描述 key对应的数据在数据源并不存在&#xff0c;每次针对此key的请求从缓存获取不到&#xff0c;请求都会压到数据源&#xff0c;从而可能压垮数据源。比如用一个不存在的用户id获取用户信息&#xff0c;不论缓存还是数据库…

美元霸权的潜在风险——无锚货币,为什么都要刺激消费

第三章 美元体系的风险结构与定价 金句导读 结果平等 没有智慧&#xff0c;优胜劣汰 没有良心。竞争都不充分。 年轻人有出路&#xff0c;穷人有活路&#xff0c;先富起来的人才能有后路。 名词解释&#xff1a; 对冲风险&#xff1a;我是卖面包的的&#xff0c;我还囤很多面…

【持续更新篇】SLAM视觉特征点汇总+ORB特征点+VINS前端

Harris角点 opencv函数 cornerHarris提取输入图像的Harris角点 检测原理 检测思想&#xff1a;使用一个固定窗口在图像上进行任意方向的滑动&#xff0c;对比滑动前后的窗口中的像素灰度变化程度&#xff0c;如果存在任意方向上的滑动&#xff0c;都有较大灰度变化&#xf…

Jetpack Compose 实战 宝可梦图鉴

文章目录前言实现效果一、架构介绍二、一些的功能点的介绍加载图片并获取主色,再讲主色设置为背景一个进度缓慢增加的圆形进度条单Activity使用navigation跳转Compose可组合项返回时页面重组的问题hiltViewModel()主要参考项目总结前言 阅读本文需要一定compose基础&#xff0…

Python爬虫|全国补充耕地项目数量爬取与分析——多进程案例

一、使用的库 import requests from lxml import etree import time import random import re import openpyxl import openpyxl from pyecharts.charts import Bar, Pie from pyecharts import options as opts from multiprocessing.dummy import Pool 二、数据爬取思路 1…

手拉手Centos7安装配置Redis7

Redis&#xff08;Remote Dictionary Server )&#xff0c;即远程字典服务&#xff0c;是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库&#xff0c;并提供多种语言的API。 Redis是一个NoSQL数据库&#xff0c;常用缓存(cache) Re…

Spark 安装及WordCount编写(Spark、Scala、java三种方法)

Spark 官网&#xff1a;Apache Spark™ - Unified Engine for large-scale data analytics Spark RDD介绍官网&#xff1a;https://spark.apache.org/docs/2.2.0/api/scala/index.html#org.apache.spark.rdd.RDD 下载好spark解压mv到软件目录 linux>mv spark-xxx-xxx /op…

统计套利策略

统计套利策略套利策略跨品种套利标的择时风控套利策略 套利是&#xff0c;某种商品在&#xff08;在同一市场或不同市场&#xff09;拥有两个价格的情况下&#xff0c;以较低的价格买进&#xff0c;较高的价格卖出&#xff0c;从而实现获利的交易方式。 比如咖啡店里有小杯、…

【jvm系列-04】精通运行时数据区共享区域---堆

JVM系列整体栏目 内容链接地址【一】初识虚拟机与java虚拟机https://blog.csdn.net/zhenghuishengq/article/details/129544460【二】jvm的类加载子系统以及jclasslib的基本使用https://blog.csdn.net/zhenghuishengq/article/details/129610963【三】运行时私有区域之虚拟机栈…

chapter-6数据库设计原则

以下课程来源于MOOC学习—原课程请见&#xff1a;数据库原理与应用 考研复习 数据库设计 数据库设计是基于应用系统需求分析中对数据的需求&#xff0c;解决数据的抽象、数据的表达和数据的存储等问题&#xff0c;其目标是设计出一个满足应用要求&#xff0c;简洁、高效、规范…

【c语言】二维数组

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; 给大家跳段街舞感谢支持&#xff01;ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ…

「计算机控制系统」3. 计算机控制系统的数学描述

差分方程 Z变换 脉冲传递函数 计算机控制系统的响应 文章目录差分方程基础知识差分方程的解Z变换定义与性质求Z变换Z变换表求Z反变换用Z变换解差分方程脉冲传递函数脉冲传递函数与差分方程的相互转化开环脉冲传递函数闭环脉冲传递函数计算机控制系统的响应差分方程 基础知识 …

Photoshop CS6安装包下载及安装教程(Photoshop 2016)

下载链接&#xff1a; https://pan.quark.cn/s/f961759b36cc “Adobe Photoshop是一款集图像扫描、编辑修改、图像制作、广告创意、图像输入输出于一体的图形图像处理软件,简称ps,对于这款软件大家应该并不陌生,而今天小编带来的是Photoshop2023中文版,也是该系列的最新版本,不…

WAF攻防-菜刀冰蝎哥斯拉流量通讯特征绕过检测反制感知

文章目录菜刀-流量&绕过&特征&检测特征绕过检测冰蝎3-流量&绕过&特征&检测特征通讯过程检测绕过哥斯拉-流量&绕过&特征&检测特征Other使用Proxifier进行流量转发至Burp抓包分析(使用Wireshake也可以) 菜刀-流量&绕过&特征&检…

Java阶段一Day21

Java阶段一Day21 文章目录Java阶段一Day21多线程并发原理使用场景创建并启动线程创建线程的方法进程线程的生命周期获取线程信息的方法教师总结新单词多线程概念线程:一个顺序的单一的程序执行流程就是一个线程。代码一句一句的有先后顺序的执行。多线程:多个单一顺序执行的流程…

最新!AI第一次有了国家标准,北大、华为、百度等单位共同编制

最近&#xff0c;国家标准全文公开系统网站正式发布了国家标准《神经网络表示与模型压缩 第一部分&#xff1a;卷积神经网络》&#xff08;GB/T 42382.1-2023&#xff09;&#xff0c;此标准由北京大学、鹏城实验室、华为、百度等16家单位共同编制。 &#xff08;来源&#xff…

考试前临时抱佛脚有用吗?这篇复习攻略会告诉你答案

夏天来了&#xff0c;大家的期末考试也将不远了。不知平时大家是如何准备考试的&#xff0c;是平时学习计划有序进行复习&#xff0c;还是考试前临时抱佛脚呢&#xff1f;今天就来跟大家讲一讲&#xff0c;学习中很重要的一个环节&#xff0c;如何复习。所以敲黑板&#xff0c;…

基于 AT89C51 单片机的数字时钟设计

目录 1.设计目的、作用 2.设计要求 3.设计的具体实现 3.1 设计原理 3.2 硬件系统设计 3.2.1 AT89C51 单片机原理 3.2.2 晶振电路设计 3.2.3 复位电路设计 3.2.4 LED 数码管显示 3.3 系统实现 3.3.1 系统仿真与调试 3.3.2 演示结果 4.总结 附录 附录 1 附录 2 1.…

【JVM】常量池

常量池&#xff08;Runtime Constant Poo&#xff09; 常量池Java中可以分为三种&#xff1a;字符串常量池&#xff08;堆&#xff09;、Class文件常量池、运行时常量池&#xff08;堆&#xff09;。 1.字符串常量池&#xff08;String Pool&#xff09; 为了提升性能和减少…