波多野结衣 蜜桃视频,国产在线精品露脸ponn,a v麻豆成人,AV在线免费小电影

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:52010
  • 待審:67
  • 小程序:12
  • 文章:1106242
  • 會員:784

當您使用 react 并擁有同一組件的多個實例時,管理狀態可能會變得很棘手。根據組件需要交互的方式,您需要以不同的方式處理狀態。這是我發現效果很好的方法。

獨立實例:將狀態保留在組件內部

如果您的組件不需要相互通信,最好將它們的狀態保留在組件內。這樣,每個實例都有自己的狀態,其中一個實例的更改不會影響其他實例。

function counter() {
  const [count, setcount] = usestate(0);

  return (
    <div>
      <p>count: {count}</p>
      <button onclick="{()"> setcount(count + 1)}&gt;increment</button>
    </div>
  );
}

// usage
<counter></counter> // instance 1
<counter></counter> // instance 2

登錄后復制

在這里,每個 counter 組件都會跟蹤自己的計數。因此,如果您單擊一個計數器中的按鈕,則不會更改另一個計數器中的計數。

依賴實例:管理父組件中的狀態

但是,如果組件需要共享某些狀態或以協調的方式工作,最好將狀態移至父組件。父級可以管理共享狀態并將其作為 props 傳遞下來。這可確保所有實例保持同步并順利協同工作。

function Parent() {
  const [sharedCount, setSharedCount] = useState(0);

  return (
    <div>
      <p>Total Count: {sharedCount}</p>
      <counter count="{sharedCount}" setcount="{setSharedCount}"></counter><counter count="{sharedCount}" setcount="{setSharedCount}"></counter>
</div>
  );
}

function Counter({ count, setCount }) {
  return (
    <div>
      <p>Count: {count}</p>
      <button onclick="{()"> setCount(count + 1)}&gt;Increment</button>
    </div>
  );
}

登錄后復制

這種方法之所以有效,是因為當狀態位于父組件中時,對該狀態的任何更新都會觸發所有實例的重新渲染,確保它們都顯示最新的 ui。如果將狀態單獨保存在每個實例中,則只有狀態發生更改的實例才會重新渲染,從而導致實例之間的 ui 不一致。

我的項目中的示例

我在構建手風琴組件時發現了這一點。這是我自己工作中的兩個例子:

獨立手風琴實例:示例。在此設置中,每個手風琴實例獨立工作。

依賴的手風琴實例:示例。在此版本中,所有手風琴實例相互依賴并保持同步。

快速回顧

如果組件單獨工作,請將狀態保存在每個組件內。

如果他們需要共享狀態或以協調的方式一起工作,請在父級中管理狀態。

在構建這些手風琴示例時,這種方法對我產生了很大的影響。希望對你也有幫助!

分享到:
標簽:多個 實例 狀態 管理 組件
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 52010

    網站

  • 12

    小程序

  • 1106242

    文章

  • 784

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定