博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
React 源码解析之React.Children
阅读量:6279 次
发布时间:2019-06-22

本文共 2152 字,大约阅读时间需要 7 分钟。

其实 React.Children 这个 API 很少用,可以跳过的,但为什么还用一个章节的篇幅去诠释它呢?因为它的源码挺有意思的,对我们编程设计和编程能力有一定的帮助。

上源码

// ReactChildren.js...export {  forEachChildren as forEach,  mapChildren as map,  countChildren as count,  onlyChild as only,  toArray,};复制代码

先说 mapChildren

// 上下文需求池里的获取最后一项const POOL_SIZE = 10;const traverseContextPool = [];function getPooledTraverseContext(  mapResult,  keyPrefix,  mapFunction,  mapContext,) {  if (traverseContextPool.length) {    const traverseContext = traverseContextPool.pop();    traverseContext.result = mapResult;    traverseContext.keyPrefix = keyPrefix;    traverseContext.func = mapFunction;    traverseContext.context = mapContext;    traverseContext.count = 0;    return traverseContext;  } else {    return {      result: mapResult,      keyPrefix: keyPrefix,      func: mapFunction,      context: mapContext,      count: 0,    };  }}// 释放贯穿上下文function releaseTraverseContext(traverseContext) {  traverseContext.result = null;  traverseContext.keyPrefix = null;  traverseContext.func = null;  traverseContext.context = null;  traverseContext.count = 0;  if (traverseContextPool.length < POOL_SIZE) {    traverseContextPool.push(traverseContext);  }}function mapIntoWithKeyPrefixInternal(children, array, prefix, func, context) {  let escapedPrefix = '';  if (prefix != null) {    escapedPrefix = escapeUserProvidedKey(prefix) + '/';  }  // 贯穿上下文  const traverseContext = getPooledTraverseContext(    array,    escapedPrefix,    func,    context,  );  // 贯穿整个子元素  traverseAllChildren(children, mapSingleChildIntoContext, traverseContext);  // 释放贯穿上下文  releaseTraverseContext(traverseContext);}function mapChildren(children, func, context) {  if(children === null) {    return children;  }  const result = [];  mapIntoWithKeyPrefixInternal(children, result, null, func, context);  return result = [];}复制代码

补个知识,mapforEach 最大区别在于没有 return;

先说 getPooledTraverseContext 函数吧,可以理解为上下文对象重用池,主要用于维护一个大小固定的重用池,当然了这个要配合 releaseTraverseContext 使用。

每次从这个池子去除一个对象去赋值给 traverseContext,用完了就用 releaseTraverseContext 去释放然后再丢回池子里。这么做主要是为了提高性能,想想频繁创建和销毁一个有很多属性的对象是很消耗性能的,你说是不是?(我还能说不嘛,哈哈)

你可以

转载于:https://juejin.im/post/5cc9c06ee51d453acd5050a7

你可能感兴趣的文章
高德开放平台开放源代码 鼓励开发者创新
查看>>
《高并发Oracle数据库系统的架构与设计》一2.5 索引维护
查看>>
《Exchange Server 2010 SP1/SP2管理实践》——2.4 部署外部网络环境
查看>>
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
《计算广告:互联网商业变现的市场与技术》一第一部分 在线广告市场与背景...
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>
Linux 性能诊断 perf使用指南
查看>>
实操分享:看看小白我如何第一次搭建阿里云windows服务器(Tomcat+Mysql)
查看>>
Sphinx 配置文件说明
查看>>
数据结构实践——顺序表应用
查看>>
python2.7 之centos7 安装 pip, Scrapy
查看>>