- ENG 
- Branchen 
- FinanzenNearshore-Softwareentwicklung für den Finanzsektor – sicher, skalierbar und Compliance-gerechte Lösungen für Banking, Zahlungsverkehr und APIs. 
- EinzelhandelSoftwareentwicklung für den Einzelhandel – E-Commerce, Kassensysteme, Logistik und KI-gestützte Personalisierung durch unsere Nearshore-Engineering-Teams. 
- Verarbeitende IndustrieNearshore-Softwareentwicklung für die Industrie – ERP-Systeme, IoT-Plattformen und Automatisierungstools zur Optimierung industrieller Abläufe. 
 
- Finanzen
- Was wir tun 
- Services
- Technologien
- KooperationsmodelleKooperationsmodelle passend zu Ihren Bedürfnissen: Komplette Nearshoring Teams, deutschsprachige Experten vor Ort mit Nearshoring-Teams oder gemischte Teams mit unseren Partnern. 
- ArbeitsweiseDurch enge Zusammenarbeit mit Ihrem Unternehmen schaffen wir maßgeschneiderte Lösungen, die auf Ihre Anforderungen abgestimmt sind und zu nachhaltigen Ergebnissen führen. 
 
- Über uns 
- Wer wir sindWir sind ein Full-Service Nearshoring-Anbieter für digitale Softwareprodukte, ein perfekter Partner mit deutschsprachigen Experten vor Ort, Ihre Business-Anforderungen stets im Blick 
- Unser TeamDas ProductDock Team ist mit modernen Technologien und Tools vertraut und setzt seit 15 Jahren zusammen mit namhaften Firmen erfolgreiche Projekte um. 
- Unsere StandorteWir sind ProductDock, ein Full-Service Nearshoring-Anbieter für Softwareprodukte mit Hauptsitz in Berlin und Entwicklungs-Hubs in Lissabon, Novi Sad, Banja Luka und Doboj. 
- Wozu NearshoringWir kombinieren Nearshore- und Fachwissen vor Ort, um Sie während Ihrer gesamten digitalen Produktreise optimal zu unterstützen. Lassen Sie uns Ihr Business gemeinsam auf das nächste digitale Level anheben. 
 
- Wer wir sind
- Unser Leistungen
- Karriere 
- Arbeiten bei ProductDockUnser Fokus liegt auf der Förderung von Teamarbeit, Kreativität und Empowerment innerhalb unseres Teams von über 120 talentierten Tech-Experten. 
- Offene StellenBegeistert es dich, an spannenden Projekten mitzuwirken und zu sehen, wie dein Einsatz zu erfolgreichen Ergebnissen führt? Dann bist du bei uns richtig. 
- Info Guide für KandidatenWie suchen wir unsere Crew-Mitglieder aus? Wir sehen dich als Teil unserer Crew und erklären gerne unseren Auswahlprozess. 
 
- Arbeiten bei ProductDock
- Newsroom 
- NewsFolgen Sie unseren neuesten Updates und Veröffentlichungen, damit Sie stets über die aktuellsten Entwicklungen von ProductDock informiert sind. 
- EventsVertiefen Sie Ihr Wissen, indem Sie sich mit Gleichgesinnten vernetzen und an unseren nächsten Veranstaltungen Erfahrungen mit Experten austauschen. 
 
- News
- Blog
- Kontakt
 
                28. Feb. 2024 •2 minutes read
React: class-based vs. functional components
ProductDock
At the year-end conference, Ernad Delić, our software developer, took the spotlight, diving into the essential distinctions between the functional and class-based React components.
React serves as a JavaScript library for building user interfaces. React apps are created by combining reusable UI building blocks called components, which consist of HTML, CSS, and JavaScript.
React: Built-in components
Built-in browser components always start with a lowercase character. Only valid, officially defined HTML elements are allowed and rendered as DOM nodes by React (i.e., displayed on the screen).
React: Custom components
Regarding the custom component, it begins with an uppercase character and is defined by the developer. It is used to encapsulate built-in or custom components. React “traverses” the custom components until it has only built-in components left.
React: JSX, Props and State
JSX is a syntax extension to JavaScript. It is similar to HTML but has the full power of JavaScript (e.g., it may output dynamic content).
<div>
	<h2>Hello {userName}</h2>
	<p>JSX is awesome!</p>
</div>Props serve as inputs to React components, allowing data to be passed from a parent component to its child component.
const CORE_CONCEPTS = [
    {
        title: "JSX",
        description: "Syntax extension to js"
    },
    {
        title: "Props",
        description: "Data passed to components"
    }
]
function App() {
    return (
        <>
            {CORE_CONCEPTS.map(coreConcept => <CoreConcept key={coreConcept.title} title={coreConcept.title}>{coreConcept.description}</CoreConcept>)}
        </>
    )
}
export default App;The State allows React components to change their output over time in response to user actions, network responses, etc.
import {useState} from "react";
export default function MainContent() {
    const [isLoading, setIsLoading] = useState(false);
    const toggleIsLoading = () => {
        setIsLoading(isLoading => !isLoading);
    };
    return (
        <main>
            <button onClick={toggleIsLoading}>Toggle loading state</button>
            {isLoading && <p>Loading...</p>}
        </main>
    )
}React Hooks allow us to choose
Furthermore, with the introduction of React Hooks, all the shortcomings that functions had about classes have been filled, which allows us to choose what we want to use.
What React developers prefer
The choice may depend on several factors, including our personal preference. For instance, a developer who has extensive experience with object-oriented programming may feel more comfortable with the class-based approach, as it aligns with their expertise.
What the React community suggests
We may want to follow the direction in which the React community is going; in that case, our choice would be functional components.
What the React project is about
In certain situations, we may find ourselves with limited options. For example, when working on a written project that involves classes, the transition to functional components can be done gradually, depending on the attitudes of the developers involved. It is worth noting that both approaches can be combined on the same project. The last case leads us to conclude that being proficient in both approaches will certainly not harm us, no matter our preference.
Overview of creating React components
To sum up, this talk briefly overviewed an alternative way of creating React components using classes and their comparison with functions.
Although functions are widely accepted and recommended to create React components, classes are still not discarded and can be found in many legacy React projects or third-party libraries. Class-based components can also be easier to understand for an Angular developer learning React because the approach is more Angular-like than functional components.
Follow our blog section for more exciting topics we will share with you in the next period. 

 
                         
     
    