精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

徹底改變我 React 開發(fā)方式的組件模式

開發(fā) 前端
本文將通過具體實(shí)例,帶你了解這一革命性的 React 組件模式,并教你如何立即將它應(yīng)用到自己的項(xiàng)目中。?

你是否曾經(jīng)遇到這樣的問題:同一個(gè) React 組件在不同場(chǎng)景下需要呈現(xiàn)完全不同的布局或樣式?最近我發(fā)現(xiàn)了一種能徹底解決這個(gè)問題的組件模式:復(fù)合組件(Compound Components)。

本文將通過具體實(shí)例,帶你了解這一革命性的 React 組件模式,并教你如何立即將它應(yīng)用到自己的項(xiàng)目中。

場(chǎng)景:組件相似但上下文不同

設(shè)想你在做一個(gè)通訊錄管理應(yīng)用,你會(huì)遇到:

  • 在單獨(dú)的頁面編輯聯(lián)系人信息。
  • 在模態(tài)框(Modal)中編輯聯(lián)系人信息。

盡管這兩種界面擁有類似的輸入框、保存/取消按鈕和標(biāo)題,但布局卻完全不同:

  • 頁面模式:整頁布局,標(biāo)題和按鈕位于頂部區(qū)域。
  • 模態(tài)框模式:緊湊布局,需遵循模態(tài)框的樣式限制。

過去,你可能會(huì)選擇:

  • 創(chuàng)建兩個(gè)單獨(dú)的組件,產(chǎn)生大量重復(fù)代碼。
  • 創(chuàng)建一個(gè)復(fù)雜的組件,根據(jù)傳入的屬性條件渲染。

但以上方式都存在缺陷,代碼難以維護(hù)且擴(kuò)展性差。

那么,有沒有更好的方式?讓我們來看如何用 復(fù)合組件模式 優(yōu)雅地解決它。

解決方案:復(fù)合組件(Compound Components)模式

復(fù)合組件模式 是一種組合式的組件設(shè)計(jì)方法。你會(huì)創(chuàng)建一個(gè)父組件管理狀態(tài)和行為,并暴露一系列子組件用于渲染不同的 UI 部分。

你可以將它理解為類似于 HTML 的 <select> 和 <option>,各個(gè)組件共同協(xié)作,但具體排列方式可以自由組合。

實(shí)際代碼使用方式如下:

編輯頁面組件示例:

// EditContactPage.jsx
function EditContactPage({ contactId }) {
  return (
    <PageLayout>
      <EditContact.Root contactId={contactId}>
        <div className="header">
          <EditContact.Title />
          <EditContact.SubmitButtons />
        </div>
        <div className="form-container">
          <EditContact.FormInputs />
        </div>
      </EditContact.Root>
    </PageLayout>
  );
}

模態(tài)框組件示例:

// ContactModal.jsx
function ContactModal({ contactId, onClose }) {
  return (
    <Modal
      onClose={onClose}
      title={<EditContact.Title />}
      footer={<EditContact.SubmitButtons />}
    >
      <EditContact.Root contactId={contactId}>
        <EditContact.FormInputs />
      </EditContact.Root>
    </Modal>
  );
}

上面代碼清晰地展示了這一模式的優(yōu)雅之處:
同樣的邏輯組件,只需稍微調(diào)整布局即可靈活地適應(yīng)不同場(chǎng)景。

如何實(shí)現(xiàn)復(fù)合組件模式?

實(shí)現(xiàn)復(fù)合組件的核心要素:

  • 使用 Context 共享狀態(tài)。
  • 父組件管理邏輯并暴露給子組件。
  • 子組件通過 Context 消費(fèi)共享狀態(tài)。

具體實(shí)現(xiàn)代碼:

步驟 1: 創(chuàng)建 Context

import { createContext, useContext, useState, useEffect } from 'react';

const EditContactContext = createContext(null);

function useEditContactContext() {
  const context = useContext(EditContactContext);
  if (!context) {
    throw new Error("子組件必須位于 EditContact.Root 內(nèi)!");
  }
  return context;
}

步驟 2: 創(chuàng)建父組件 Root 管理狀態(tài)

function Root({ contactId, children }) {
  const [formData, setFormData] = useState({
    name: '',
    email: '',
    phone: ''
  });
  const [error, setError] = useState(null);
  const [loading, setLoading] = useState(false);

  // 獲取聯(lián)系人信息
  const { data: contact } = useGetContact(contactId);

  // 保存聯(lián)系人信息
  const saveContact = useSaveContact({
    onSuccess: () => {/*成功處理邏輯*/},
    onError: (err) => setError(err.message)
  });

  useEffect(() => {
    if (contact) {
      setFormData(contact);
    }
  }, [contact]);

  const handleSubmit = async () => {
    setLoading(true);
    try {
      await saveContact.mutateAsync({ id: contactId, ...formData });
    } finally {
      setLoading(false);
    }
  };

  const contextValue = {
    contact,
    formData,
    setFormData,
    error,
    loading,
    handleSubmit
  };

  return (
    <EditContactContext.Provider value={contextValue}>
      {children}
    </EditContactContext.Provider>
  );
}

步驟 3: 創(chuàng)建子組件消費(fèi) Context

標(biāo)題組件:

function Title() {
  const { contact } = useEditContactContext();
  return <>{contact ? `編輯 ${contact.name}` : "創(chuàng)建聯(lián)系人"}</>;
}

提交按鈕組件:

function SubmitButtons() {
  const { handleSubmit, loading } = useEditContactContext();
  return (
    <div>
      <button onClick={handleSubmit} disabled={loading}>
        {loading ? '保存中...' : '保存'}
      </button>
      <button>取消</button>
    </div>
  );
}

表單輸入組件:

function FormInputs() {
  const { formData, setFormData, error } = useEditContactContext();

  const handleChange = (e) => {
    const { name, value } = e.target;
    setFormData(prev => ({ ...prev, [name]: value }));
  };

  return (
    <form>
      {error && <div className="error">{error}</div>}
      <input name="name" value={formData.name} onChange={handleChange} placeholder="姓名" />
      <input name="email" value={formData.email} onChange={handleChange} placeholder="郵箱" />
      <input name="phone" value={formData.phone} onChange={handleChange} placeholder="電話" />
    </form>
  );
}

步驟 4: 導(dǎo)出復(fù)合組件

const EditContact = {
  Root,
  Title,
  SubmitButtons,
  FormInputs
};

export default EditContact;

為什么這種模式值得推薦?

我在實(shí)際使用后,感受到它強(qiáng)大的優(yōu)勢(shì):

  • 靈活布局:自由組合子組件,實(shí)現(xiàn)不同布局。
  • 邏輯復(fù)用:核心邏輯統(tǒng)一管理,避免重復(fù)。
  • 高可讀性:JSX 明確展示組件結(jié)構(gòu),更易理解。
  • 維護(hù)性強(qiáng):修改邏輯只需改一處。
  • 社區(qū)認(rèn)可:很多流行組件庫(如 Chakra UI、Radix UI、shadcn/ui)廣泛使用。

何時(shí)使用這種模式?

以下場(chǎng)景適合使用復(fù)合組件模式:

  • 同一組件需適應(yīng)不同布局。
  • 復(fù)雜狀態(tài)需跨多個(gè)子組件共享。
  • 開發(fā)組件庫或設(shè)計(jì)系統(tǒng),需提供布局組合靈活性。

總結(jié)要點(diǎn)

  • 復(fù)合組件讓組件布局更靈活。
  • 使用 React Context 管理共享狀態(tài)。
  • 明確的邏輯與布局分離,提升可維護(hù)性。
  • 尤其適合需適應(yīng)不同場(chǎng)景布局的組件。

下次再遇到需要實(shí)現(xiàn)靈活布局的 React 組件時(shí),不妨嘗試一下復(fù)合組件模式。或許你也會(huì)像我一樣,從此徹底改變 React 開發(fā)的方式。

責(zé)任編輯:姜華 來源: 大遷世界
相關(guān)推薦

2025-08-08 10:30:00

Eyevinn開源部署

2014-09-19 10:44:00

微軟Windows

2025-06-27 01:22:00

MCP工具服務(wù)器

2021-11-19 22:49:05

物聯(lián)網(wǎng)銷售設(shè)備

2020-06-08 22:32:07

物聯(lián)網(wǎng)銷售方式IOT

2023-03-20 15:34:00

ChatGPT人工智能

2025-10-29 08:00:00

2016-08-05 13:54:16

云計(jì)算

2015-08-18 09:24:49

云技術(shù)工作應(yīng)用人工智能

2020-06-02 16:33:11

物聯(lián)網(wǎng)IoT施管理服務(wù)模式

2025-03-07 07:00:00

AI人工智能

2022-03-09 16:08:17

區(qū)塊鏈加密貨幣技術(shù)

2023-03-15 10:26:58

物聯(lián)網(wǎng)智能建筑數(shù)字技術(shù)

2013-01-15 09:52:38

AWS云服務(wù)亞馬遜

2022-10-26 11:06:16

機(jī)器學(xué)習(xí)農(nóng)業(yè)

2023-05-04 14:48:25

AR

2018-07-24 11:05:54

邊緣計(jì)算網(wǎng)絡(luò)云計(jì)算

2025-07-28 06:47:16

CSS if()函數(shù)SASS

2009-04-21 09:06:59

Windows 8微軟操作系統(tǒng)

2024-01-08 13:48:00

物聯(lián)網(wǎng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久亚洲a v| 日韩中文第一页| 成人午夜免费在线视频| 天堂中文在线资| 日韩成人免费在线| 美女视频久久黄| 中国黄色a级片| 久久久久久久性潮| 亚洲国产精品一区二区www在线| 精品一区二区三区免费毛片| 一道本在线视频| 亚洲乱码视频| 久久久国产在线视频| 亚洲天堂成人av| 国产日韩中文在线中文字幕| 91久久精品一区二区二区| 四虎4hu永久免费入口| 飘雪影视在线观看免费观看| 黄一区二区三区| 奇米四色中文综合久久| 亚洲国产成人精品综合99| 国产成人精品免费视| 亚洲精品在线一区二区| 日本在线一二三区| 中文字幕这里只有精品| 一区二区视频免费在线观看| 日韩av在线电影观看| 好吊色视频一区二区| 精品一区二区三区在线视频| 日本韩国欧美精品大片卡二| 欧美毛片在线观看| 91精品国产乱码久久久久久久| 亚洲全黄一级网站| 国产乱了高清露脸对白| 亚洲码欧美码一区二区三区| 欧美日产在线观看| 久草青青在线观看| 精品捆绑调教一区二区三区| 一区二区日韩av| 中文字幕欧美人与畜| 福利视频在线播放| 久久久777精品电影网影网| 国内外成人免费视频| 亚洲国产成人在线观看| 国产在线精品免费| 成人精品一区二区三区电影黑人| 亚洲 小说区 图片区| 久久美女性网| 日韩av电影中文字幕| 欧美日韩综合在线观看| 日韩亚洲在线| 午夜免费在线观看精品视频| 精品在线视频观看| 国内揄拍国内精品久久| 精品国产欧美一区二区三区成人| 久久免费手机视频| 日韩欧美精品| 日韩一区二区精品视频| 中文字幕无码日韩专区免费| 日韩久久电影| 精品国产一区二区三区久久久狼| 精品在线观看一区| 国产精品x453.com| 成人97在线观看视频| 欧美黄色免费看| 亚洲国产日本| 国产精品 欧美在线| 中日精品一色哟哟| 久久99九九99精品| 亚洲va电影大全| 亚洲精品18p| 99精品视频一区二区| 欧美日韩免费观看一区| 国产福利在线| 亚洲美女屁股眼交| 亚洲国产成人精品无码区99| 中文字幕21页在线看| 在线免费观看视频一区| 国产免费中文字幕| 91蜜桃臀久久一区二区| 亚洲精品一区二区久| 少妇视频在线播放| 欧美 日韩 国产 一区| 78色国产精品| 小泽玛利亚一区二区三区视频| 另类中文字幕网| y111111国产精品久久婷婷| 熟妇高潮一区二区高潮| 国产欧美精品区一区二区三区| 亚洲欧美久久234| 欧洲性视频在线播放| 欧美性猛交xxxx偷拍洗澡 | 亚洲电影影音先锋| 久久久久久久成人| 无码人妻aⅴ一区二区三区有奶水| 久久国产精品第一页| 国产成人免费观看| 国产黄在线观看免费观看不卡| 综合网在线视频| 男女激情无遮挡| 日韩毛片免费看| 亚洲精品成人久久| 可以免费看av的网址| 在线视频观看日韩| 国产日韩在线播放| 性感美女视频一二三| 国产精品短视频| 国产美女无遮挡网站| 国产美女视频一区二区| 亚洲欧洲黄色网| 久草视频在线资源| 蜜桃视频在线观看一区二区| 国产一区二区无遮挡| 欧洲美女少妇精品| 色综合久久久网| 中文字幕99页| 香蕉久久网站| 国产精品第100页| 隣の若妻さん波多野结衣| 国产精品美女久久久久久久久| 波多野结衣之无限发射| 国产精品一区二区三区四区在线观看 | 无码人妻av一区二区三区波多野| 成人午夜免费av| 美国av在线播放| 成人黄色视屏网站| 亚洲美女久久久| 日本一区二区欧美| 国产传媒日韩欧美成人| 亚洲一区二区三区加勒比| 免费欧美网站| 欧美性xxxx极品hd满灌| 国产伦精品一区二区三区妓女下载 | 五月激情丁香一区二区三区| 日本少妇一区二区三区| 97欧美在线视频| 国产精品久久久久久久一区探花| 亚洲人视频在线观看| 亚洲午夜日本在线观看| 国产成人精品综合久久久久99| 小小影院久久| 国产日韩欧美综合| 欧美人xxx| 欧美午夜电影一区| 日本精品在线观看视频| 久久九九国产| 欧美一区二区高清在线观看| 伊人色综合一区二区三区影院视频| 亚洲国产欧美自拍| 圆产精品久久久久久久久久久| 成人福利电影精品一区二区在线观看| 国产成人在线小视频| 一区二区日韩| 国内外成人免费激情在线视频网站| 亚洲经典一区二区三区| 午夜天堂影视香蕉久久| 国产精品无码一区二区三| 亚洲久久在线| 欧美不卡福利| 亚洲日本在线观看视频| 中文字幕国内精品| 一级黄色片在线| 亚洲视频综合在线| 中文字幕无人区二| 一区免费观看视频| 亚洲精品自拍第一页| 中文字幕av免费在线观看| 中文字幕在线免费观看视频| 日韩免费一区二区三区在线播放| 美女的奶胸大爽爽大片| 国产福利一区二区三区在线视频| 日韩精品一区二区在线视频| 超碰精品在线| 91精品国产高清久久久久久91| 天堂中文在线8| 在线一区二区视频| 激情高潮到大叫狂喷水| 国产精品一区二区久激情瑜伽| 国产av熟女一区二区三区| 国产精品极品国产中出| 欧美亚洲在线观看| www亚洲人| 欧美一卡2卡3卡4卡| 国产在线一二区| 26uuu亚洲| 国产色视频在线播放| 欧美一区成人| 精品免费二区三区三区高中清不卡 | 亚洲一区三区电影在线观看| 91成人app| 亚州av一区二区| 91xxx在线观看| 欧美草草影院在线视频| 中文字幕在线欧美| 亚洲欧美日韩系列| 久久久久久久久免费看无码 | 韩国三级与黑人| 国产欧美成人| 在线天堂一区av电影| 大奶在线精品| 成人h视频在线| 黄色18在线观看| 日韩中文字幕国产| 天堂中文在线看| 欧美人体做爰大胆视频| 日本熟妇毛茸茸丰满| 中文字幕乱码亚洲精品一区| 国产午夜在线一区二区三区| 轻轻草成人在线| 精品人妻少妇一区二区| 色中色综合网| 明星裸体视频一区二区| 日本精品视频| 国产精品免费在线免费| 7777kkk亚洲综合欧美网站| 少妇高潮久久77777| 你懂的在线视频| 精品成人一区二区三区| 国产又大又长又粗| 欧洲av在线精品| 色婷婷在线观看视频| 亚洲精品视频在线看| 日本人亚洲人jjzzjjz| 97se亚洲国产综合自在线不卡| 91蝌蚪视频在线| 美女国产一区二区三区| 女人另类性混交zo| 一本综合精品| 野外做受又硬又粗又大视频√| 亚洲草久电影| 亚洲一区二区在线看| 国产日产精品一区二区三区四区的观看方式| 99久久伊人精品影院| 日日狠狠久久| 国产精品日韩欧美大师| 奇米777日韩| 91国产在线精品| 波多野结衣在线播放| 欧美成人中文字幕在线| 国产在线更新| 欧美超级乱淫片喷水| 美女免费久久| 色妞一区二区三区| 香蕉视频在线免费看| 在线日韩中文字幕| 国产大学生校花援交在线播放| 亚洲欧洲美洲在线综合| 久久电影中文字幕| 亚洲人成网7777777国产| 日本中文字幕电影在线观看 | 91精品视频在线看| 亚洲精品无播放器在线播放| 国产日韩在线播放| 日韩免费在线电影| 91在线高清视频| 日韩欧美高清一区二区三区| 91精品免费| 波多野结衣在线一区二区 | 青青青在线视频免费观看| 久久中文欧美| 中文久久久久久| 麻豆国产91在线播放| 日本高清一区二区视频| 国产麻豆一精品一av一免费 | 妞干网在线播放| 国产精品vip| 免费看国产一级片| 免费日韩精品中文字幕视频在线| 国产视频在线视频| 久久精品国产第一区二区三区| 中文字幕视频三区| 国产电影一区在线| 亚洲欧美日韩偷拍| 久久九九久久九九| 极品色av影院| 性久久久久久久| 波多野结衣 久久| 欧美日韩国产三级| 亚洲精品国偷拍自产在线观看蜜桃 | 尤蜜粉嫩av国产一区二区三区| 国内精品伊人久久久久影院对白| 中文字幕 欧美 日韩| 99r精品视频| 美国美女黄色片| 亚洲精品欧美激情| 日本道在线观看| 欧美性xxxxxxxx| 精品国产伦一区二区三区| 亚洲精品美女在线观看播放| 91精彩视频在线观看| 欧美丰满老妇厨房牲生活 | 婷婷另类小说| 全黄性性激高免费视频| 日韩精品亚洲一区二区三区免费| 在线a免费观看| 久久综合九色综合欧美就去吻| 99热99这里只有精品| 精品久久久精品| 国产三级小视频| 亚洲欧美日韩网| 91亚洲天堂| 国产精品7m视频| 国产+成+人+亚洲欧洲在线| 日韩一区国产在线观看| 亚洲福利国产| 在线免费观看av网| 久久精品日产第一区二区三区高清版 | 国产精品嫩草影院精东| 日韩av网站大全| 天天干在线视频论坛| 国产精品美女在线| 理论片一区二区在线| 亚洲天堂第一区| 美女视频黄频大全不卡视频在线播放| www.男人天堂| 亚洲男人的天堂在线aⅴ视频| 国产乱码77777777| 亚洲黄色片网站| 中文在线字幕免费观看| 国产精品久久久91| 五月综合久久| 国产天堂视频在线观看| 国内精品免费在线观看| 久久婷婷五月综合| 欧美天堂在线观看| 欧美少妇bbw| 久久91亚洲精品中文字幕| 久久69成人| 日韩影视精品| 日韩精品成人一区二区三区| 亚洲AV无码国产精品| 亚洲国产乱码最新视频| www黄色在线观看| 久热精品视频在线| 日韩综合久久| 中文字幕一区综合| 美国毛片一区二区三区| 亚洲а∨天堂久久精品2021| 欧美日韩美女在线观看| 天堂av2024| 97在线视频一区| 国产香蕉精品| 国精产品一区一区三区视频| 粉嫩一区二区三区性色av| 久久久精品99| 精品国产91久久久久久久妲己| 久久久久黄久久免费漫画| 99在线视频首页| 在线日韩电影| www.超碰97| 欧美性xxxxxx| 国产区视频在线| 国产精品高潮粉嫩av| 久久高清免费| 中文 日韩 欧美| 一区二区三区鲁丝不卡| 亚洲欧美另类视频| 91精品国产精品| 嫩草一区二区三区| 中文字幕第80页| 国产精品高清亚洲| 国产精品一区二区三区在线免费观看| 久久艹在线视频| 加勒比色综合久久久久久久久| 国产精品无码一区二区在线| 久久亚洲私人国产精品va媚药| 无码一区二区三区| 日韩资源在线观看| 亚洲1区在线| 极品美女扒开粉嫩小泬| 久久精品日产第一区二区三区高清版| 中文字幕一区二区三区人妻四季 | 欧美一区二区在线视频| 四季久久免费一区二区三区四区| 国产精品传媒毛片三区| 国产精品最新自拍| 欧美a在线播放| 日韩欧美国产一区在线观看| 蜜桃视频www网站在线观看| 区一区二区三区中文字幕| 久久99日本精品| 精品无码久久久久久久久| 亚洲欧美国产精品久久久久久久 | 麻豆9191精品国产| 中文字幕伦理片| 精品三级在线观看| 韩国精品主播一区二区在线观看| 国产精品h视频| av午夜精品一区二区三区| 亚洲av人无码激艳猛片服务器| 欧美美女15p| 蜜臀91精品国产高清在线观看| 在线观看国产一级片| 亚洲va欧美va天堂v国产综合| 大片免费播放在线视频| 99re在线视频观看| 青娱乐精品视频在线| 国产午夜福利片| 日韩在线小视频| 久久99国产成人小视频|