suchen
HeimWeb-Frontendjs-TutorialHyperapp: Die 1 KB JavaScript-Bibliothek zum Erstellen von Front-End-Apps

Hyperapp: The 1 KB JavaScript Library for Building Front-End Apps

hyperapp: Eine optimierte JavaScript-Bibliothek zum Erstellen von Funktions-Webanwendungen

HyperApp ist eine leichte JavaScript-Bibliothek zum Erstellen von Funktionswebanwendungen. Es kombiniert einen pragmatischen, von ELM inspirierten Ansatz für das Staatsmanagement mit einer VDOM-Engine, die KETTED-Updates und Lebenszyklusereignisse unterstützt-ohne sich auf andere Bibliotheken zu verlassen. Die Quellcodegröße, nachdem sie minimiert und GZIP -komprimiert ist, beträgt ca. 1 KB.

Dieses Tutorial führt Sie mit Hyperapp vor und hilft Ihnen beim schnellen Einstieg mit einigen Code -Beispielen. Ich nehme an, Sie haben ein gewisses Verständnis von HTML und JavaScript, müssen aber keine Erfahrung mit anderen Frameworks haben.

Schlüsselpunkte

  • HyperApp ist eine kompakte JavaScript -Bibliothek, mit der Entwickler Webanwendungen erstellen können, die die staatliche Verwaltung mit einer virtuellen DOM -Engine mit einer Größe von ca. 1 KB kombinieren.
  • Mit HyperApp erstellte
  • -Anwendungen bestehen aus einem einzelnen Zustandsobjekt, Operationen, die Zustände ändern, und Ansichten, die Zustände und Operationen in Benutzeroberflächen umwandeln. Status ist ein normales JavaScript -Objekt, das das Datenmodell der Anwendung beschreibt und unveränderlich ist.
  • HyperApp verwendet ein virtuelles DOM, was eine Beschreibung des tatsächlichen DOM ist, der in jedem Rendering -Zyklus von Grund auf neu erstellt wird. Dies bringt eine hohe Effizienz, da es normalerweise nur wenige Knoten verändert werden müssen.
  • HyperApp kann mit JSX (einer JavaScript -Spracherweiterung zur Darstellung dynamischer HTML) oder allein verwendet werden. Sie können auch Hyperapp von einem CDN wie UNPKG laden, das weltweit über das Fenster.HyperApp -Objekt erhältlich ist.
  • HyperApp ist im Vergleich zu anderen Bibliotheken wie React oder Vue einfacher, da es klein ist und eine vollständige Lösung zum Erstellen von Webanwendungen ist. Es entwickelt das Konzept der Sichtweise weiter als staatliche Funktion und verfügt über integrierte staatliche Managementlösungen, die von ELM inspiriert sind.

Hallo Welt

Wir werden mit einer einfachen Demonstration beginnen, die alle Komponenten zusammenarbeitet. Sie können diesen Code auch online ausprobieren.

import { h, app } from "hyperapp";
// @jsx h

const state = { count: 0 };

const actions = {
  down: () => state => ({ count: state.count - 1 }),
  up: () => state => ({ count: state.count + 1 })
};

const view = (state, actions) => (
  <div>
    <h1 id="state-count">{state.count}</h1>
    <button onclick={actions.down}>-</button>
    <button onclick={actions.up}>+</button>
  </div>
);

app(state, actions, view, document.body);

Dies ist ungefähr das, was jede HyperApp -Anwendung aussieht: ein einzelnes Zustandsobjekt, einen Betrieb, der Zustände füllt, und eine Ansicht, die Zustände und Operationen in Benutzeroberflächen umwandelt.

In der Funktion app kopieren wir Ihren Zustand und Ihre Operationen (es ist unhöflich, Objekte zu ändern, die wir nicht besitzen) und übergeben sie an die Ansicht. Wir wickeln Ihre Aktionen auch so ein, dass die Anwendung jedes Mal neu geführt wird, wenn sich der Staat ändert.

app(state, actions, view, document.body);

Status ist ein normales JavaScript -Objekt, das Ihr Anwendungsdatenmodell beschreibt. Es ist auch unveränderlich. Um es zu ändern, müssen Sie die Aktionen definieren und anrufen.

const state = { count: 0 };

In der Ansicht können Sie die Eigenschaften des Staates anzeigen und feststellen, welche Teile der Benutzeroberfläche angezeigt oder versteckt sind usw.

<h1 id="state-count">{state.count}</h1>

Sie können auch eine Aktion an ein DOM -Ereignis hinzufügen oder eine Aktion in Ihrem eigenen Inline -Event -Handler aufrufen.

import { h, app } from "hyperapp";
// @jsx h

const state = { count: 0 };

const actions = {
  down: () => state => ({ count: state.count - 1 }),
  up: () => state => ({ count: state.count + 1 })
};

const view = (state, actions) => (
  <div>
    <h1 id="state-count">{state.count}</h1>
    <button onclick={actions.down}>-</button>
    <button onclick={actions.up}>+</button>
  </div>
);

app(state, actions, view, document.body);

Die Operation wird den Status nicht direkt ändern, sondern einen neuen Clip des Staates zurückgeben. Wenn Sie versuchen, den Status in einer Aktion zu ändern und ihn dann zurückzusetzen, wird die Ansicht nicht wie erwartet neu tendern.

app(state, actions, view, document.body);

app CALL gibt das mit dem Rendern des Status-Update-View-Rendering angeschlossene Betriebsobjekts zurück. Sie erhalten dieses Objekt auch in Sichtfunktionen und Operationen. Es ist sehr nützlich, dieses Objekt der Außenwelt auszusetzen, da Sie mit Ihrer Anwendung aus einem anderen Programm, Framework oder nativem JavaScript mit Ihrer Anwendung interagieren können.

const state = { count: 0 };

(Der Rest des Inhalts ist ähnlich, aber der Satz wird Synonyme und Satzstrukturanpassungen ersetzt, wobei die ursprüngliche Bedeutung unverändert bleibt und die Länge zu lang ist, hier weggelassen)

Zusammenfassung: HyperApp bietet eine leichte Lösung zum Erstellen effizienter Webanwendungen mit extrem kleiner Größe und einfachem Design. Es bietet leistungsstarke Funktionen in der staatlichen Verwaltung und im virtuellen DOM, während es einfach zu lernende und nutzende Funktionen beibehält. Unabhängig davon, ob es sich um ein kleines Projekt oder eine große Anwendung handelt, kann HyperApp eine effiziente und flexible Entwicklungserfahrung bieten.

(Das Bild bleibt das ursprüngliche Format und die Position unverändert)

Das obige ist der detaillierte Inhalt vonHyperapp: Die 1 KB JavaScript-Bibliothek zum Erstellen von Front-End-Apps. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Apr 11, 2025 am 08:23 AM

Ich habe eine funktionale SaaS-Anwendung mit mehreren Mandanten (eine EdTech-App) mit Ihrem täglichen Tech-Tool erstellt und Sie können dasselbe tun. Was ist eine SaaS-Anwendung mit mehreren Mietern? Mit Multi-Tenant-SaaS-Anwendungen können Sie mehrere Kunden aus einem Sing bedienen

So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

Dieser Artikel zeigt die Frontend -Integration mit einem Backend, das durch die Genehmigung gesichert ist und eine funktionale edtech SaaS -Anwendung unter Verwendung von Next.js. erstellt. Die Frontend erfasst Benutzerberechtigungen zur Steuerung der UI-Sichtbarkeit und stellt sicher, dass API-Anfragen die Rollenbasis einhalten

JavaScript: Erforschung der Vielseitigkeit einer WebspracheJavaScript: Erforschung der Vielseitigkeit einer WebspracheApr 11, 2025 am 12:01 AM

JavaScript ist die Kernsprache der modernen Webentwicklung und wird für seine Vielfalt und Flexibilität häufig verwendet. 1) Front-End-Entwicklung: Erstellen Sie dynamische Webseiten und einseitige Anwendungen durch DOM-Operationen und moderne Rahmenbedingungen (wie React, Vue.js, Angular). 2) Serverseitige Entwicklung: Node.js verwendet ein nicht blockierendes E/A-Modell, um hohe Parallelitäts- und Echtzeitanwendungen zu verarbeiten. 3) Entwicklung von Mobil- und Desktop-Anwendungen: Die plattformübergreifende Entwicklung wird durch reaktnative und elektronen zur Verbesserung der Entwicklungseffizienz realisiert.

Die Entwicklung von JavaScript: Aktuelle Trends und ZukunftsaussichtenDie Entwicklung von JavaScript: Aktuelle Trends und ZukunftsaussichtenApr 10, 2025 am 09:33 AM

Zu den neuesten Trends im JavaScript gehören der Aufstieg von Typenkripten, die Popularität moderner Frameworks und Bibliotheken und die Anwendung der WebAssembly. Zukunftsaussichten umfassen leistungsfähigere Typsysteme, die Entwicklung des serverseitigen JavaScript, die Erweiterung der künstlichen Intelligenz und des maschinellen Lernens sowie das Potenzial von IoT und Edge Computing.

Entmystifizieren JavaScript: Was es tut und warum es wichtig istEntmystifizieren JavaScript: Was es tut und warum es wichtig istApr 09, 2025 am 12:07 AM

JavaScript ist der Eckpfeiler der modernen Webentwicklung. Zu den Hauptfunktionen gehören eine ereignisorientierte Programmierung, die Erzeugung der dynamischen Inhalte und die asynchrone Programmierung. 1) Ereignisgesteuerte Programmierung ermöglicht es Webseiten, sich dynamisch entsprechend den Benutzeroperationen zu ändern. 2) Die dynamische Inhaltsgenerierung ermöglicht die Anpassung der Seiteninhalte gemäß den Bedingungen. 3) Asynchrone Programmierung stellt sicher, dass die Benutzeroberfläche nicht blockiert ist. JavaScript wird häufig in der Webinteraktion, der einseitigen Anwendung und der serverseitigen Entwicklung verwendet, wodurch die Flexibilität der Benutzererfahrung und die plattformübergreifende Entwicklung erheblich verbessert wird.

Ist Python oder JavaScript besser?Ist Python oder JavaScript besser?Apr 06, 2025 am 12:14 AM

Python eignet sich besser für Datenwissenschaft und maschinelles Lernen, während JavaScript besser für die Entwicklung von Front-End- und Vollstapel geeignet ist. 1. Python ist bekannt für seine prägnante Syntax- und Rich -Bibliotheks -Ökosystems und ist für die Datenanalyse und die Webentwicklung geeignet. 2. JavaScript ist der Kern der Front-End-Entwicklung. Node.js unterstützt die serverseitige Programmierung und eignet sich für die Entwicklung der Vollstapel.

Wie installiere ich JavaScript?Wie installiere ich JavaScript?Apr 05, 2025 am 12:16 AM

JavaScript erfordert keine Installation, da es bereits in moderne Browser integriert ist. Sie benötigen nur einen Texteditor und einen Browser, um loszulegen. 1) Führen Sie sie in der Browser -Umgebung durch, indem Sie die HTML -Datei durch Tags einbetten. 2) Führen Sie die JavaScript -Datei nach dem Herunterladen und Installieren von node.js nach dem Herunterladen und Installieren der Befehlszeile aus.

Wie sende ich Benachrichtigungen, bevor eine Aufgabe in Quartz beginnt?Wie sende ich Benachrichtigungen, bevor eine Aufgabe in Quartz beginnt?Apr 04, 2025 pm 09:24 PM

So senden Sie im Voraus Aufgabenbenachrichtigungen in Quartz Wenn der Quartz -Timer eine Aufgabe plant, wird die Ausführungszeit der Aufgabe durch den Cron -Ausdruck festgelegt. Jetzt...

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion