Back To Articles

[React] Lifting The State Up

🧑🏻‍💻 海豹人 Sealman 📅 September 8, 2021

Article Image

Props 的用途是讓父子元件之間傳遞狀態,使子元件也能使用到父元件定義的狀態,而子元件的狀態也能透過 Lifting State 的方式提升給父元件使用。

初次看到這個觀念時,覺得這就像是 Vue 2 的 Emit,都是 From Child to Parent 的作法。

在 React 中,當父元件需要取得由子元件生成的 data 時,我們可以使用 Lifting The State Up 的技巧,同時因為狀態不是存放在父元件,子元件的改動並不會讓父元件執行 Re-rendering,某方面來說也是一種效能優化。

STEP 1:父元件傳遞一個函式給子元件

在 Parent component 建立一個函式,這個函式 (onXXX) 會作為 props 傳遞給 Child。

// ParentComponent

const xxxHandler = () => {
  // do something...
}

// Return JSX
;<ChildComponent onXXX={xxxHandler} />

STEP 2:子元件存取 Props 調用函式

在 Child 裡面執行 props.onXxx 函式,就等同執行了 Parent 的 xxxHandler 函式,因為函式傳遞的是 Pointer (By Reference)

// ChildComponent

props.onXxx()

STEP 3:從子元件傳入參數,達到 State 提升

從 Child 放入參數,透過呼叫函式來傳遞給 Parent。

// ChildComponent

const childData = {
  title: 'Child Title',
  data: new Date(),
}

props.onXxx(childData)

這時候 Parent 就可以從參數獲得 Child 的資料了,此時就完成了提升 State 的動作了。

// ParentComponent

const xxxHandler = enteredChildData => {
  // do something...
  const childData = { ...enteredChildData }
  console.log(childData)
}

// Return JSX
;<ChildComponent onXXX={xxxHandler} />

Recap

  • Lifting The State Up

References