最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 搭建React源码调试环境

    正文概述 掘金(果冻丨小布丁)   2021-03-23   890

    写在前面

    • React源码版本:V17.0.2
    • 日期:2021-3-16 17:17:17
    • create-react-app 搭建

    参考:

    github.com/nannongrous… github.com/bubucuo/Deb…

    1. 搭建项目

    npx create-react-app debug-react
    cd debug-react
    npm run eject
    

    2. 克隆源码 v17.0.2

    git clone https://github.com/facebook/react.git
    

    3. 将源码放在 src 目录下 debug-react/src

    4. 修改 webpack alias 配置文件 debug-react/config/webpack.config.js

    resolve: {
        alias: {
            'react-native': 'react-native-web',
            'react': path.resolve(__dirname, '../src/react/packages/react'),
            'react-dom': path.resolve(__dirname, '../src/react/packages/react-dom'),
            'shared': path.resolve(__dirname, '../src/react/packages/shared'),
            'react-reconciler': path.resolve(__dirname, '../src/react/packages/react-reconciler'),
        }    
    }
    

    5. 配置webpack和eslint中的全局变量

    修改/config/env.js:

    const stringified = {
        // 保留原有配置...,
        "__DEV__": true,
        "__PROFILE__": true,
        "__UMD__": true
    };
    

    根目录下新建.eslintrc.json文件:

    {
      "extends": "react-app",
      "globals": {
          "__DEV__": true,
          "__PROFILE__": true,
          "__UMD__": true
      }
    }
    

    6. 修改源码内文件:

    /src/react/.eslintrc.js

    将 `extends: []` 数组置空
    
    删掉 `/src/react/.eslintrc.js` 文件中所有 `no-for-of-loops`, `no-function-declare-after-return`。
    
    在 `/src/react/` 下搜索 `react-internal`,把包含 `react-internal` 的`注释行`和`代码行`全部删掉。
    

    /src/react/packages/react-reconciler/src/ReactFiberHostConfig.js

    // 注释掉
    // import invariant from 'shared/invariant';
    // invariant(false, 'This module must be shimmed by a specific renderer.');
    
    // 添加此行
    export * from "./forks/ReactFiberHostConfig.dom";
    

    /src/react/packages/shared/ReactSharedInternals.js

    // 注释掉
    /* import * as React from 'react';
    
    const ReactSharedInternals =
      React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED; */
    
    // 添加此行
    import ReactSharedInternals from '../react/src/ReactSharedInternals';
    
    export default ReactSharedInternals;
    

    /src/react/packages/shared/invariant.js

    export default function invariant(condition, format, a, b, c, d, e, f) {
      // 添加此行
      if (condition) return;
    
      throw new Error(
        "Internal React error: invariant() is meant to be replaced at compile " +
          "time. There is no runtime version."
      );
    }
    

    /src/react/packages/react-dom/src/client 下新建 util.js 文件

    /**
     * Copyright (c) Facebook, Inc. and its affiliates.
     *
     * This source code is licensed under the MIT license found in the
     * LICENSE file in the root directory of this source tree.
     *
     * @flow
     */
    
    export const isPrimaryRenderer = true;
    export const warnsIfNotActing = true;
    
    // This initialization code may run even on server environments
    // if a component just imports ReactDOM (e.g. for findDOMNode).
    // Some environments might not have setTimeout or clearTimeout.
    export const scheduleTimeout: any =
      typeof setTimeout === 'function' ? setTimeout : (undefined: any);
    export const cancelTimeout: any =
      typeof clearTimeout === 'function' ? clearTimeout : (undefined: any);
    export const noTimeout = -1;
    
    // -------------------
    //     Microtasks
    // -------------------
    export const supportsMicrotasks = true;
    export const scheduleMicrotask: any =
      typeof queueMicrotask === 'function'
        ? queueMicrotask
        : typeof Promise !== 'undefined'
        ? callback =>
            Promise.resolve(null)
              .then(callback)
              .catch(handleErrorInNextTick)
        : scheduleTimeout; // TODO: Determine the best fallback here.
    
    function handleErrorInNextTick(error) {
      setTimeout(() => {
        throw error;
      });
    }
    
    export const supportsMutation = true;
    export const supportsHydration = true;
    export const supportsTestSelectors = true;
    

    然后在 /src/react/packages/react-dom/src/client/ReactDOMHostConfig.js 中找到 所有在 util.js 中定义的常量 并删除掉, 最后在末尾导出 util.js

    export * from './util';
    

    起源地下载网 » 搭建React源码调试环境

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元