ホームページ > ウェブフロントエンド > jsチュートリアル > コンポーネントベースのアーキテクチャの主な特徴

コンポーネントベースのアーキテクチャの主な特徴

Mary-Kate Olsen
リリース: 2024-10-21 18:30:02
オリジナル
433 人が閲覧しました

Key characteristic of Component-Based Architecture

React JS で実装された コンポーネントベースのアーキテクチャ の 5 つの主要な特徴を次に示します。これらの例は、React コンポーネントが

の特性をどのように具体化するかを示します。
  1. 再利用性
  2. カプセル化、互換性
  3. スケーラビリティ
  4. 保守性
  5. 構成

再利用性
コンポーネントはアプリケーションのさまざまな部分で再利用できます。
例: 複数回使用される Button コンポーネント

function Button({ label, onClick }) {
  return <button onClick={onClick}>{label}</button>;
}

function App() {
  return (
    <div>
      <Button label="Submit" onClick={() => alert('Submit clicked')} />
      <Button label="Cancel" onClick={() => alert('Cancel clicked')} />
    </div>
  );
}
ログイン後にコピー

カプセル化
コンポーネントはロジックとスタイルをカプセル化し、外部の干渉を防ぎます。
例: ユーザーデータをカプセル化する UserProfile コンポーネント

function UserProfile({ name, email }) {
  return (
    <div>
      <h3>{name}</h3>
      <p>Email: {email}</p>
    </div>
  );
}

function App() {
  return (
    <UserProfile name="John Doe" email="john@example.com" />
  );
}
ログイン後にコピー

互換性
アプリの全体的な機能に影響を与えることなく、コンポーネントを交換または置き換えることができます。
例: PrimaryButton と SecondaryButton
を交換する

function PrimaryButton({ label, onClick }) {
  return <button style={{ backgroundColor: 'blue', color: 'white' }} onClick={onClick}>{label}</button>;
}

function SecondaryButton({ label, onClick }) {
  return <button style={{ backgroundColor: 'gray', color: 'white' }} onClick={onClick}>{label}</button>;
}

function App({ usePrimary }) {
  return (
    <div>
      {usePrimary ? <PrimaryButton label="Click Me" onClick={() => alert('Primary clicked')} /> : 
                   <SecondaryButton label="Click Me" onClick={() => alert('Secondary clicked')} />}
    </div>
  );
}
ログイン後にコピー

スケーラビリティ
コンポーネントを使用すると、既存のコンポーネントに影響を与えることなく機能を追加することができ、簡単に拡張できます。
例: アプリを拡張するために製品コンポーネントを追加する

function Product({ name, price }) {
  return (
    <div>
      <h3>{name}</h3>
      <p>Price: ${price}</p>
    </div>
  );
}

function ProductList() {
  const products = [
    { name: 'iPhone 13', price: 999 },
    { name: 'Samsung Galaxy S21', price: 799 },
    { name: 'Google Pixel 6', price: 599 },
  ];

  return (
    <div>
      {products.map((product, index) => (
        <Product key={index} name={product.name} price={product.price} />
      ))}
    </div>
  );
}

function App() {
  return <ProductList />;
}
ログイン後にコピー

保守性
コンポーネントは分離されているため、個別に簡単に保守および更新できます。
例: アプリの残りの部分に影響を与えずに製品コンポーネントを更新する

function Product({ name, price }) {
  // Add a new feature to show if the product is on sale
  const isOnSale = price < 700;
  return (
    <div>
      <h3>{name}</h3>
      <p>Price: ${price} {isOnSale && <span>(On Sale!)</span>}</p>
    </div>
  );
}

function App() {
  return (
    <div>
      <Product name="Google Pixel 6" price={599} />
    </div>
  );
}
ログイン後にコピー

構成
コンポーネントを組み合わせたり、構成したりして、より複雑な UI を構築できます。
例: ヘッダー、製品、フッターを 1 つのページにまとめる

function Header() {
  return <h1>Welcome to My Shop</h1>;
}

function Product({ name, price }) {
  return (
    <div>
      <h3>{name}</h3>
      <p>Price: ${price}</p>
    </div>
  );
}

function Footer() {
  return <footer>Contact us at shop@example.com</footer>;
}

function Page() {
  return (
    <div>
      <Header />
      <Product name="Apple Watch" price={399} />
      <Footer />
    </div>
  );
}

function App() {
  return <Page />;
}
ログイン後にコピー

以上がコンポーネントベースのアーキテクチャの主な特徴の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート