• react第十单元(children的深入用法-React.Children对象上的方法)


    第十单元(children的深入用法-React.Children对象上的方法)

    #课程目标

    1. 理解什么是children
    2. 掌握React.Children对象上的方法

    #知识点

    1. 什么是children

     上图中我们看到了,我们之前学过的React.createElement方法,现在大家发现jsx的内容,全部都体现在了该方法上;那么React.createElement其实是有三个参数的,第三个参数被称之为children,也就是子元素;看下图:  这个时候,第三个参数也体现出来了; 那么我们可以发现children其实也是外部传递的数据,只不过传递的是react元素。那么我们在组件的内部应该用this.props.children去接收这些元素; 在组件的内部:

    console.log(this.props.children) => [<span>哈哈哈</span>]
    
    1
    1. React.Children对象上的方法

    我们已经知道在组件的内部如何获取到children了,那么针对children的处理,我们需要特别的注意,因为来自外界的children可以能是0个,也可能是1个,也可能是很多个;我们处理起来是比较麻烦的,但是React给我们提供了一些可以来处理children的方法;这些方法都挂在了React.Children这个对象上:

    map 方法

    React.Children.map
    
    1

    该方法用来遍历children,使用方法如下:

    React.Children.map(this.props.children,(item,key)=>{  //… });
    
    1

    该方法会把children看做一个数组,进行遍历,item表示数组中的每个元素,key表示每个元素对应的索引;每个回调函数的返回值会被组合成为一个数组变成map方法的返回值;

    forEach 方法

    React.Children.forEach
    
    1

    该方法也是来遍历children的,用法如下:

    React.Children.forEach (this.props.children,(item,key)=>{  //… });
    
    1

    该方法类似于map,但是没有返回值

    count 方法

    该方法用来返回children中所包含组件的数量,用法如下:

    React.Children.count(this.props.children)
    
    1

    only

    该方法用来返回组件唯一的children,如果children不唯一将不允许调用该方法;

    #授课思路

    #案例和作业

    基于swiper封装一个轮播组件,要有父组件和每一个滑块组件

    封装弹窗组件 组件内容可以自定义

  • 相关阅读:
    《人月神话》阅读笔记(三)
    记账软件开发进度(六)
    记账软件开发进度(五)
    记账软件开发进度(四)
    《人月神话》阅读笔记(二)
    记账软件开发进度(三)
    package bufio
    Go语言:net/http包的使用模式和源码解析
    package http
    Golang系列中常用包
  • 原文地址:https://www.cnblogs.com/yzy521/p/14131768.html
Copyright © 2020-2023  润新知