Component() — react Function Reference
Architecture documentation for the Component() function in reactive-control-dependency-from-interleaved-reactivity-while.js from the react codebase.
Entity Profile
Dependency Diagram
graph TD 0f767372_0961_2ea4_4ac0_13aeb544d784["Component()"] 031e15ea_4166_7e41_6bd1_cae4b9a44ec0["reactive-control-dependency-from-interleaved-reactivity-while.js"] 0f767372_0961_2ea4_4ac0_13aeb544d784 -->|defined in| 031e15ea_4166_7e41_6bd1_cae4b9a44ec0 style 0f767372_0961_2ea4_4ac0_13aeb544d784 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
compiler/packages/babel-plugin-react-compiler/src/__tests__/fixtures/compiler/reactive-control-dependency-from-interleaved-reactivity-while.js lines 1–24
function Component(props) {
// a and b are independent but their mutations are interleaved, so
// they get grouped in a reactive scope. this means that a becomes
// reactive since it will effectively re-evaluate based on a reactive
// input
const a = [];
const b = [];
b.push(props.cond);
a.push(null);
// Downstream consumer of a, which initially seems non-reactive except
// that a becomes reactive, per above
const c = [a];
let x;
while (c[0][0]) {
x = 1;
}
// The values assigned to `x` are non-reactive, but the value of `x`
// depends on the "control" value `c[0]` which becomes reactive via
// being interleaved with `b`.
// Therefore x should be treated as reactive too.
return [x];
}
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/reactive-control-dependency-from-interleaved-reactivity-while.js.
Where is Component() defined?
Component() is defined in compiler/packages/babel-plugin-react-compiler/src/__tests__/fixtures/compiler/reactive-control-dependency-from-interleaved-reactivity-while.js at line 1.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free