AgentSkillsCN

calculate-derived-state-during-rendering

在渲染过程中计算派生状态

SKILL.md
--- frontmatter
name: calculate-derived-state-during-rendering
description: Calculate Derived State During Rendering

Calculate Derived State During Rendering

If a value can be computed from current props/state, do not store it in state or update it in an effect. Derive it during render to avoid extra renders and state drift. Do not set state in effects solely in response to prop changes; prefer derived values or keyed resets instead.

Incorrect (redundant state and effect):

tsx
function Form() {
  const [firstName, setFirstName] = useState('First');
  const [lastName, setLastName] = useState('Last');
  const [fullName, setFullName] = useState('');

  useEffect(() => {
    setFullName(firstName + ' ' + lastName);
  }, [firstName, lastName]);

  return <p>{fullName}</p>;
}

Correct (derive during render):

tsx
function Form() {
  const [firstName, setFirstName] = useState('First');
  const [lastName, setLastName] = useState('Last');
  const fullName = firstName + ' ' + lastName;

  return <p>{fullName}</p>;
}

References: You Might Not Need an Effect