码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React 状态管理 - Context API 前世今生(上)旧版v16.3前


    目录

    扩展学习资料

    Context api before React v16.3

    Context

    实战使用-Context

    Context VS Props

    Context

    Props

    Context的缺陷


    New Context API 的实践

    扩展学习资料

    名称

    链接

    备注

    new context api

    https://reactjs.org/docs/context.html

    英文

    old context api

    https://5abc31d8be40f1556f06c4be--reactjs.netlify.app/docs/context.html

    context api 问题

    https://medium.com/@gobindathakur/problems-with-previous-react-context-api-317b247d78d4

    英文

    Context api before React v16.3

    官方说:功能强大,但是不推荐使用

    Context

    Context: React 的‘上下文’,贯穿了整个React,不需要层层传递。

    • childContextTypes 父级组件定义,声明Context对象属性。【定义属性】
    • getChildContext 父级组件定义,返回Context对象,方法名是约定的。【属性赋值】
    • contextTypes 在任意层级的子级组件中定义,就可以在子级组件使用context。【子级使用】

    实战使用-Context

    1. import React, { Component } from 'react';
    2. import PropTypes from 'prop-types';
    3. import CustomButton from './components/customButton';
    4. // 父组件
    5. export default class Home extends Component {
    6. // 定义类型
    7. static childContextTypes = {
    8. color: PropTypes.string,
    9. }
    10. constructor(props) {
    11. super(props);
    12. this.state = {
    13. color: '#28a745',
    14. };
    15. }
    16. // 属性赋值
    17. getChildContext() {
    18. // 动态值state
    19. const { color } = this.state;
    20. return {
    21. color,
    22. }
    23. }
    24. render() {
    25.     return (
    26.       <div>
    27.         <CustomButton>
    28.           React Context Demo
    29.         CustomButton>
    30.       div>
    31.     );
    32. }
    33. }
    1. // 子组件
    2. export default function CustomButton(props, context) {
    3. const { color } = context;
    4. const { children } = props;
    5. return (
    6. <button type="button" style={{ color }}>
    7. { children }
    8. button>
    9. );
    10. }
    11. // 定义context类型
    12. CustomButton.contextTypes = {
    13. color: PropTypes.string,
    14. }
    15. CustomButton.propTypes = {
    16.   children: PropTypes.string,
    17. };
    18. CustomButton.defaultProps = {
    19.   children: '默认文案',
    20. };

    Context VS Props

    Context

    • 父级(根节点)与应用节点都需要强制类型声明,关键字不一样。
    • 全局上下文,贯穿了整个应用。
    Props

    • 应用节点需要类型声明,非强制。
    • 只能进行逐级传递,一旦中间断掉,就会传递失败。

    Context的缺陷

    • setState()时,getChildContext()也会触发。父级组件的shouldComponentUpdate返回false,就会不执行getChildContext(),引起更新失败。导致子组件接收到的context还是老的,破坏了传递流程。
    • PureComponent或者自定义的优化可能接收不到Context的更新。
  • 相关阅读:
    R语言—基本统计分析
    v-model 简单理解
    【Laravel系列7.9】测试
    密码学-SHA-1算法
    接口流量突增,如果是你,怎样做好性能调优?
    C++程序设计基础实践:学生信息管理系统
    java内嵌浏览器CEF-JAVA、jcef、java chrome
    BFS模板:844. 走迷宫
    2022年制造业单项冠军行业研究报告
    java基于ssm+vue+elementui的多用户博客管理系统
  • 原文地址:https://blog.csdn.net/qq_35729091/article/details/133697610
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号