Lose Kopplung der UI-Ebene in der Webentwicklung
Dieses Mal werde ich Ihnen die lose Kopplung der UI-Ebene in der Webentwicklung vorstellen. Was sind die Vorsichtsmaßnahmen bei der Verwendung der losen Kopplung der UI-Ebene in der Webentwicklung? sehen.
In der Webentwicklung wird die Benutzeroberfläche durch drei Ebenen definiert, die isoliert sind und miteinander interagieren.
HTML wird verwendet, um die Daten und Semantik der Seite zu definieren.
CSS wird verwendet, um Stile zur Seite hinzuzufügen und visuelle Funktionen zu erstellen.
JS wird verwendet, um Verhalten hinzuzufügen die Seite, um sie interaktiver zu machen
Zur losen Kopplung möchte ich ein paar Worte sagen. Wenn Sie eine Komponente ändern können, ohne andere Komponenten zu ändern, liegt eine lose Kopplung vor. Bei großen Mehrpersonensystemen, bei denen viele Personen an der Codepflege beteiligt sind, ist eine lose Kopplung für die Wartbarkeit des Codes von entscheidender Bedeutung. Sie möchten unbedingt, dass Entwickler den Code anderer Leute nicht beschädigen, wenn sie einen Teil des Codes ändern. Wenn der Inhalt jeder Komponente eines großen Systems begrenzt ist, wird eine lose Kopplung erreicht. Im Wesentlichen muss jede Komponente dünn genug gehalten werden, um eine lockere Kopplung zu gewährleisten. Je weniger man über die Komponenten weiß, desto besser lässt sich das Gesamtsystem bilden.
Eines ist zu beachten: Komponenten, die zusammenarbeiten, können keine „Keine Kopplung“ erreichen. In allen Systemen teilen Komponenten einige Informationen, um ihre Arbeit zu erledigen. Es ist leicht zu verstehen, dass unser Ziel darin besteht, sicherzustellen, dass Änderungen an einer Komponente nicht regelmäßig Auswirkungen auf andere Teile haben.
Wenn eine Web-Benutzeroberfläche lose gekoppelt ist, ist das Debuggen einfach. Probleme im Zusammenhang mit Text oder Struktur können durch Durchsuchen von HTML lokalisiert werden. Wenn ein stilbezogenes Problem auftritt, wissen Sie, dass das Problem im CSS liegt. Bei diesen Verhaltensproblemen schließlich ist Ihre Fähigkeit, direkt zu JS zu gehen, um das Problem zu finden, ein zentraler Bestandteil der Wartbarkeit von Webschnittstellen.
Im WebPage-Zeitalter befürworten wir die Trennung der drei Ebenen von HTML/CSS/JS. Beispielsweise ist es verboten, die Inline-Attribute des DOM zum Binden von Listenern zu verwenden,
Man kommt nicht umhin, sich zu fragen: Machen wir einen Rückschritt?
Die Geschichte dreht sich manchmal, und auf den ersten Blick dachte ich, ich würde zurückgehen. Tatsächlich hat sich die Spirale umgekehrt und steht an einem neuen Ausgangspunkt. ——Yu Bo „Evolution des Web-R&D-Modells“
In der traditionellen WebPage-Ära war die Komponentenunterstützung nicht hoch, sowohl auf Sprachebene als auch auf Framework-Ebene. Denken Sie darüber nach, es gibt kein JS, das dies nicht tut unterstützen nativ Module (vor der ES6-Ära) und jQuery. Um steigende Wartungskosten zu vermeiden, wird daher die Best Practice der dreischichtigen Trennung empfohlen. Mit dem Aufkommen von ES6 und dem Front-End-MV*-Framework hat sich das gesamte Front-End-Entwicklungsmodell geändert. Sie werden feststellen, dass das Frontend nicht nur Seiten schreibt, sondern auch mehr WebApps schreibt. Der Umfang und die Komplexität der Anwendungen unterscheiden sich von denen im WebPage-Zeitalter.
React ist ein sehr typischer Vertreter. Es schlägt vor, JSX zum Schreiben von HTML zu verwenden und die Seitenstruktur und Seitenlogik direkt zusammen zu schreiben. Wenn dies in die WebPage-Ära eingeordnet würde, würde es meiner Meinung nach direkt als typisches Anti-Pattern-Lehrmaterial angesehen werden, aber in der WebApp-Ära wird es von den meisten Menschen akzeptiert und verwendet. Durch die vom React-Team vorgeschlagene Einbeziehung von CSS in JS möchten sie auch CSS in JS schreiben, sodass die Front-End-Entwicklung vollständig von JS dominiert wird und die Komponentisierung gründlicher erfolgt (ich habe keine eingehende Recherche und kein Verständnis von CSS in JS durchgeführt). , und es gibt keine wirklich großen praktischen Erfahrungen im Projekt, daher behalte ich jetzt immer noch eine abwartende Haltung bei und verwende weiterhin das bisherige SASS und LESS für die CSS-Entwicklung.
Obwohl sich die Entwicklungsmodelle der beiden Web-Ära dramatisch verändert haben, gibt es immer noch einige allgemeine Prinzipien, die Sie hinsichtlich des dreischichtigen losen Kopplungsdesigns befolgen müssen:
Extrahieren Sie JS aus CSS. Frühe IE8- und frühere Browser erlaubten das Schreiben von JS in CSS (wenn Sie kein Beispiel schreiben, ist dies ein Anti-Muster, es ist besser, wenn Sie sich nicht daran erinnern können, was zu Leistungsproblemen führt, und was noch beängstigender ist). dass es in Zukunft schwierig sein wird, es aufrechtzuerhalten. Aber ich glaube, dass keiner von Ihnen hier Zugriff auf diese Art von Code haben wird, was in Ordnung ist.
CSS aus JS extrahieren. Es bedeutet nicht, dass Sie CSS in JS nicht ändern dürfen. Stattdessen können Sie den Stil indirekt ändern, indem Sie die Klasse ändern. Siehe das folgende Beispiel:
// 不好的写法element.style.color = 'red'; element.style.left = '10px'; element.style.top = '100px'; element.style.visibility = 'visible';// 好的写法.reveal { color: red; left: 10px; top: 100px; visibility: visible; } element.classList.add('.reveal');
Weil der CSS-Klassenname zu einer Kommunikationsbrücke zwischen CSS und JS werden kann. Im Lebenszyklus der Seite kann JS den Klassennamen des Elements nach Belieben hinzufügen und löschen. Der durch className definierte Stil befindet sich im CSS-Code. Stile in CSS können jederzeit geändert werden, ohne dass JS aktualisiert werden muss. JS sollte Stile nicht direkt manipulieren, um eine lose Kopplung mit CSS aufrechtzuerhalten.
Es gibt eine Situation, in der die Verwendung des Stilattributs akzeptabel ist: wenn Sie ein Element auf der Seite relativ zu einem anderen Element positionieren oder die gesamte Seite neu positionieren müssen. Diese Berechnung kann nicht in CSS durchgeführt werden, daher können Sie style.top, style.left, style.bottom und style.rght verwenden, um das Element korrekt zu positionieren. Definieren Sie die Standardattribute dieses Elements in CSS und ändern Sie diese Standardwerte in Javascript.
Angesichts der aktuellen Situation, in der das Front-End HTML und JS zusammen geschrieben hat, werde ich nicht auf die Praxis der Trennung der beiden im Originalbuch eingehen. Aber denken Sie bei all dem Unsinn daran: Vorhersehbarkeit führt zu schnellerem Testen und Entwickeln, und wenn Sie wissen (anstatt zu raten), wo Sie mit dem Debuggen von Fehlern beginnen müssen, lässt sich das Problem schneller lösen und die Gesamtqualität Ihres Codes ist höher.
Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!
Empfohlene Lektüre:
Wie man JS zur Referenz- und Wertübergabe verwendet
Wie man einen Knoten erstellt .js-Schnittstelle
Das obige ist der detaillierte Inhalt vonLose Kopplung der UI-Ebene in der Webentwicklung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Dieses KI-gestützte Programmiertool hat in dieser Phase der schnellen KI-Entwicklung eine große Anzahl nützlicher KI-gestützter Programmiertools zu Tage gefördert. KI-gestützte Programmiertools können die Entwicklungseffizienz verbessern, die Codequalität verbessern und Fehlerraten reduzieren. Sie sind wichtige Helfer im modernen Softwareentwicklungsprozess. Heute wird Dayao Ihnen 4 KI-gestützte Programmiertools vorstellen (und alle unterstützen die C#-Sprache). https://github.com/YSGStudyHards/DotNetGuide1.GitHubCopilotGitHubCopilot ist ein KI-Codierungsassistent, der Ihnen hilft, Code schneller und mit weniger Aufwand zu schreiben, sodass Sie sich mehr auf Problemlösung und Zusammenarbeit konzentrieren können. Git

Am 3. März 2022, weniger als einen Monat nach der Geburt von Devin, dem weltweit ersten KI-Programmierer, entwickelte das NLP-Team der Princeton University einen Open-Source-KI-Programmierer-SWE-Agenten. Es nutzt das GPT-4-Modell, um Probleme in GitHub-Repositorys automatisch zu lösen. Die Leistung des SWE-Agenten auf dem SWE-Bench-Testsatz ist ähnlich wie die von Devin, er benötigt durchschnittlich 93 Sekunden und löst 12,29 % der Probleme. Durch die Interaktion mit einem dedizierten Terminal kann der SWE-Agent Dateiinhalte öffnen und durchsuchen, die automatische Syntaxprüfung verwenden, bestimmte Zeilen bearbeiten sowie Tests schreiben und ausführen. (Hinweis: Der obige Inhalt stellt eine geringfügige Anpassung des Originalinhalts dar, die Schlüsselinformationen im Originaltext bleiben jedoch erhalten und überschreiten nicht die angegebene Wortbeschränkung.) SWE-A

Tutorial zur Entwicklung mobiler Anwendungen in der Go-Sprache Da der Markt für mobile Anwendungen weiterhin boomt, beginnen immer mehr Entwickler damit, sich mit der Verwendung der Go-Sprache für die Entwicklung mobiler Anwendungen zu befassen. Als einfache und effiziente Programmiersprache hat die Go-Sprache auch großes Potenzial für die Entwicklung mobiler Anwendungen gezeigt. In diesem Artikel wird detailliert beschrieben, wie die Go-Sprache zum Entwickeln mobiler Anwendungen verwendet wird, und es werden spezifische Codebeispiele angehängt, um den Lesern den schnellen Einstieg und die Entwicklung eigener mobiler Anwendungen zu erleichtern. 1. Vorbereitung Bevor wir beginnen, müssen wir die Entwicklungsumgebung und die Tools vorbereiten. Kopf

Zusammenfassung der fünf beliebtesten Go-Sprachbibliotheken: wesentliche Werkzeuge für die Entwicklung, die spezifische Codebeispiele erfordern Seit ihrer Geburt hat die Go-Sprache große Aufmerksamkeit und Anwendung gefunden. Als aufstrebende effiziente und prägnante Programmiersprache ist die schnelle Entwicklung von Go untrennbar mit der Unterstützung umfangreicher Open-Source-Bibliotheken verbunden. In diesem Artikel werden fünf beliebte Go-Sprachbibliotheken vorgestellt. Diese Bibliotheken spielen eine wichtige Rolle bei der Go-Entwicklung und bieten Entwicklern leistungsstarke Funktionen und praktische Entwicklungserfahrung. Um die Verwendung und Funktion dieser Bibliotheken besser zu verstehen, werden wir sie gleichzeitig anhand konkreter Codebeispiele erläutern.

Die Android-Entwicklung ist eine arbeitsreiche und spannende Aufgabe, und die Auswahl einer geeigneten Linux-Distribution für die Entwicklung ist besonders wichtig. Welche der vielen Linux-Distributionen eignet sich am besten für die Android-Entwicklung? In diesem Artikel wird dieses Problem unter verschiedenen Aspekten untersucht und spezifische Codebeispiele aufgeführt. Werfen wir zunächst einen Blick auf einige derzeit beliebte Linux-Distributionen: Ubuntu, Fedora, Debian, CentOS usw. Sie alle haben ihre eigenen Vorteile und Eigenschaften.

Cockpit ist eine webbasierte grafische Oberfläche für Linux-Server. Es soll vor allem neuen/erfahrenen Benutzern die Verwaltung von Linux-Servern erleichtern. In diesem Artikel besprechen wir die Cockpit-Zugriffsmodi und wie Sie den Administratorzugriff von CockpitWebUI auf das Cockpit umstellen. Inhaltsthemen: Cockpit-Eingabemodi Ermitteln des aktuellen Cockpit-Zugriffsmodus Aktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Deaktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Fazit Cockpit-Eingabemodi Das Cockpit verfügt über zwei Zugriffsmodi: Eingeschränkter Zugriff: Dies ist die Standardeinstellung für den Cockpit-Zugriffsmodus. In diesem Zugriffsmodus können Sie vom Cockpit aus nicht auf den Webbenutzer zugreifen

„VSCode verstehen: Wofür wird dieses Tool verwendet?“ „Als Programmierer, egal ob Sie Anfänger oder erfahrener Entwickler sind, können Sie auf den Einsatz von Codebearbeitungstools nicht verzichten.“ Unter vielen Bearbeitungstools ist Visual Studio Code (kurz VSCode) bei Entwicklern als Open-Source-, leichter und leistungsstarker Code-Editor sehr beliebt. Wofür genau wird VSCode verwendet? Dieser Artikel befasst sich mit den Funktionen und Verwendungsmöglichkeiten von VSCode und stellt spezifische Codebeispiele bereit, um den Lesern zu helfen

PHP gehört zum Backend in der Webentwicklung. PHP ist eine serverseitige Skriptsprache, die hauptsächlich zur Verarbeitung serverseitiger Logik und zur Generierung dynamischer Webinhalte verwendet wird. Im Vergleich zur Front-End-Technologie wird PHP eher für Back-End-Vorgänge wie die Interaktion mit Datenbanken, die Verarbeitung von Benutzeranfragen und die Generierung von Seiteninhalten verwendet. Anschließend wird anhand konkreter Codebeispiele die Anwendung von PHP in der Backend-Entwicklung veranschaulicht. Schauen wir uns zunächst ein einfaches PHP-Codebeispiel zum Herstellen einer Verbindung zu einer Datenbank und zum Abfragen von Daten an:
