Heim >Web-Frontend >js-Tutorial >Hauptmerkmal der komponentenbasierten Architektur
Hier sind 5 Schlüsselmerkmale der Komponentenbasierten Architektur, die in React JS implementiert sind. Diese Beispiele zeigen, wie React-Komponenten die Eigenschaften von
verkörpernWiederverwendbarkeit
Komponenten können in verschiedenen Teilen der Anwendung wiederverwendet werden.
Beispiel: Eine mehrfach verwendete Button-Komponente
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> ); }
Kapselung
Komponenten kapseln ihre Logik und Stile und verhindern so Eingriffe von außen.
Beispiel: UserProfile-Komponente, die Benutzerdaten kapselt
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" /> ); }
Austauschbarkeit
Komponenten können ausgetauscht oder ersetzt werden, ohne die Gesamtfunktionalität der App zu beeinträchtigen.
Beispiel: Austausch eines PrimaryButton mit 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> ); }
Skalierbarkeit
Komponenten erleichtern die Skalierung durch das Hinzufügen weiterer Funktionen, ohne dass sich dies auf vorhandene Komponenten auswirkt.
Beispiel: Weitere Produktkomponenten hinzufügen, um die App zu skalieren
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 />; }
Wartbarkeit
Die Komponenten sind isoliert, sodass sie problemlos unabhängig voneinander gewartet und aktualisiert werden können.
Beispiel: Aktualisierung der Produktkomponente ohne Auswirkungen auf den Rest der App
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> ); }
Komposition
Komponenten können kombiniert oder zusammengestellt werden, um komplexere Benutzeroberflächen zu erstellen.
Beispiel: Kopf-, Produkt- und Fußzeile auf einer einzigen Seite zusammenfassen
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 />; }
Das obige ist der detaillierte Inhalt vonHauptmerkmal der komponentenbasierten Architektur. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!