suchen
HeimWeb-Frontendjs-TutorialLose 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!

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
JavaScript -Engines: Implementierungen vergleichenJavaScript -Engines: Implementierungen vergleichenApr 13, 2025 am 12:05 AM

Unterschiedliche JavaScript -Motoren haben unterschiedliche Auswirkungen beim Analysieren und Ausführen von JavaScript -Code, da sich die Implementierungsprinzipien und Optimierungsstrategien jeder Engine unterscheiden. 1. Lexikalanalyse: Quellcode in die lexikalische Einheit umwandeln. 2. Grammatikanalyse: Erzeugen Sie einen abstrakten Syntaxbaum. 3. Optimierung und Kompilierung: Generieren Sie den Maschinencode über den JIT -Compiler. 4. Führen Sie aus: Führen Sie den Maschinencode aus. V8 Engine optimiert durch sofortige Kompilierung und versteckte Klasse.

Jenseits des Browsers: JavaScript in der realen WeltJenseits des Browsers: JavaScript in der realen WeltApr 12, 2025 am 12:06 AM

Zu den Anwendungen von JavaScript in der realen Welt gehören die serverseitige Programmierung, die Entwicklung mobiler Anwendungen und das Internet der Dinge. Die serverseitige Programmierung wird über node.js realisiert, die für die hohe gleichzeitige Anfrageverarbeitung geeignet sind. 2. Die Entwicklung der mobilen Anwendungen erfolgt durch reaktnative und unterstützt die plattformübergreifende Bereitstellung. 3.. Wird für die Steuerung von IoT-Geräten über die Johnny-Five-Bibliothek verwendet, geeignet für Hardware-Interaktion.

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.

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
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor