Component() — react Function Reference
Architecture documentation for the Component() function in reordering-across-blocks.js from the react codebase.
Entity Profile
Dependency Diagram
graph TD f7443930_29e0_ba71_1bfe_6e0141bc7508["Component()"] 3996b5a6_df14_ebe1_bd7a_148f82e83e3d["reordering-across-blocks.js"] f7443930_29e0_ba71_1bfe_6e0141bc7508 -->|defined in| 3996b5a6_df14_ebe1_bd7a_148f82e83e3d style f7443930_29e0_ba71_1bfe_6e0141bc7508 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
compiler/packages/babel-plugin-react-compiler/src/__tests__/fixtures/compiler/reordering-across-blocks.js lines 3–44
function Component({config}) {
/**
* The original memoization is optimal in the sense that it has
* one output (the object) and one dependency (`config`). Both
* the `a` and `b` functions will have to be recreated whenever
* `config` changes, cascading to update the object.
*
* However, we currently only consider consecutive scopes for
* merging, so we first see the `a` scope, then the `b` scope,
* and see that the output of the `a` scope is used later -
* so we don't merge these scopes, and so on.
*
* The more optimal thing would be to build a dependency graph
* of scopes so that we can see the data flow is along the lines
* of:
*
* config
* / \
* [a] [b]
* \ /
* [object]
*
* All the scopes (shown in []) are transitively dependent on
* `config`, so they can be merged.
*/
const object = useMemo(() => {
const a = event => {
config?.onA?.(event);
};
const b = event => {
config?.onB?.(event);
};
return {
b,
a,
};
}, [config]);
return <Stringify value={object} />;
}
Domain
Subdomains
Source
Frequently Asked Questions
What does Component() do?
Component() is a function in the react codebase, defined in compiler/packages/babel-plugin-react-compiler/src/__tests__/fixtures/compiler/reordering-across-blocks.js.
Where is Component() defined?
Component() is defined in compiler/packages/babel-plugin-react-compiler/src/__tests__/fixtures/compiler/reordering-across-blocks.js at line 3.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free