Maison interface Web js tutoriel Couplage lâche de la couche d'interface utilisateur dans le développement Web

Couplage lâche de la couche d'interface utilisateur dans le développement Web

Jun 04, 2018 am 10:11 AM
web 开发

Cette fois, je vais vous présenter le couplage lâche de la couche UI dans le développement Web. Quelles sont les précautions lors de l'utilisation du couplage lâche de la couche UI dans le développement Web. Voici des cas pratiques, prenons un. regarder.

Dans le développement Web, l'interface utilisateur est définie par trois couches isolées et interagissant les unes avec les autres.

HTML est utilisé pour définir les données et la sémantique de la page

CSS est utilisé pour ajouter des styles à la page et créer des fonctionnalités visuelles

JS est utilisé pour ajouter un comportement à la page pour la rendre plus Interactivité

Concernant le couplage lâche, permettez-moi de dire quelques mots. Lorsque vous pouvez modifier un composant sans changer d’autres composants, vous obtenez un couplage lâche. Pour les grands systèmes multi-personnes, où de nombreuses personnes sont impliquées dans la maintenance du code, le couplage lâche est essentiel à la maintenabilité du code. Vous voulez absolument que les développeurs ne cassent pas le code des autres lorsqu'ils modifient une partie du code. Lorsque le contenu de chaque composant d’un grand système est limité, un couplage lâche est obtenu. Essentiellement, chaque composant doit être suffisamment fin pour garantir un couplage lâche. Moins les composants sont connus, mieux il est possible de former le système global.

Une chose à noter : les composants travaillant ensemble ne peuvent pas atteindre "aucun couplage". Dans tous les systèmes, les composants partagent certaines informations pour faire leur travail. Il est facile de comprendre que notre objectif est de garantir que les modifications apportées à un composant n'affectent pas régulièrement d'autres pièces.

Si une interface utilisateur Web est faiblement couplée, elle est facile à déboguer. Les problèmes liés au texte ou à la structure peuvent être localisés en effectuant une recherche HTML. Lorsqu'un problème lié au style survient, vous savez que le problème vient du CSS. Enfin, pour ces problèmes de comportement, votre capacité à accéder directement à JS pour trouver le problème est un élément essentiel de la maintenabilité des interfaces Web.

A l'ère des pages Web, nous prônons la séparation des trois couches HTML/CSS/JS. Par exemple, il est interdit d'utiliser les attributs inline du DOM pour lier des auditeurs, . onclick=handler>test< /button>Écrire comme ça vous fera pulvériser. Cependant, à l'ère des WebApp, les frameworks MVVM et MVC représentés par React (à proprement parler, React n'est qu'un framework axé sur la couche View), ils recommandent tous d'écrire HTML, CSS et JS ensemble, et vous pouvez souvent voir à le code qui lie l'écouteur d'événements en ligne.

Vous ne pouvez pas vous empêcher de vous demander si nous reculons ?

L'histoire tourne parfois en rond, et au premier coup d'oeil j'ai cru que j'y retournais. En fait, la spirale s’est inversée et se trouve à un nouveau point de départ. ——Yu Bo "Évolution du modèle de R&D Web"

À l'ère traditionnelle des pages Web, la prise en charge des composants n'était pas élevée, tant au niveau du langage qu'au niveau du framework. Pensez-y, il n'y a pas de JS qui ne le fasse pas. prennent en charge nativement les modules (avant l'ère ES6) et jQuery, donc afin d'éviter d'augmenter les coûts de maintenance, la meilleure pratique de séparation à trois couches est recommandée. Avec l’essor d’ES6 et du framework front-end MV*, l’ensemble du modèle de développement front-end a changé. Vous constaterez que le front-end ne consiste pas seulement à écrire des pages, mais également à écrire davantage de WebApps. L'échelle et la complexité des applications sont différentes de celles de l'ère des pages Web.

React est un représentant très typique. Il propose d'utiliser JSX pour écrire du HTML, en écrivant directement ensemble la structure et la logique de la page. Si cela était placé à l'ère des pages Web, je pense qu'il serait directement considéré comme un matériel pédagogique anti-modèle typique, mais à l'ère des applications Web, il est accepté et utilisé par la plupart des gens ; Y compris CSS dans JS proposé par l'équipe React, ils souhaitent également écrire CSS dans JS afin que le développement front-end soit complètement dominé par JS et que la composantisation soit effectuée de manière plus approfondie (je n'ai pas fait de recherche et de compréhension approfondies de CSS dans JS , et il n'y a pas de véritable expérience pratique à grande échelle dans le projet, donc maintenant je maintiens toujours une attitude attentiste et je continue à utiliser les précédents SASS et LESS pour le développement CSS).

Bien que les modèles de développement des deux ères du Web aient radicalement changé, il existe encore quelques principes généraux que vous devez suivre concernant la conception du couplage lâche à trois couches :

Extraire JS du CSS. Les premiers navigateurs IE8 et précédents autorisaient l'écriture de JS en CSS (si vous n'écrivez pas d'exemple, c'est un anti-modèle, il vaut mieux ne pas vous en souvenir). Cela entraînera des problèmes de performances, et ce qui est encore plus effrayant, c'est). qu'il sera difficile de maintenir à l'avenir. Mais je crois qu'aucun d'entre vous ici n'aura accès à ce genre de code, ce qui est très bien.

Extraire le CSS de JS. Ce n'est pas que vous ne pouvez pas modifier le CSS dans JS. Cela ne signifie pas que vous n'êtes pas autorisé à modifier le style directement. Au lieu de cela, vous pouvez modifier le style indirectement en modifiant la classe. Voir l'exemple suivant :

// 不好的写法element.style.color = &#39;red&#39;;
element.style.left = &#39;10px&#39;;
element.style.top = &#39;100px&#39;;
element.style.visibility = &#39;visible&#39;;// 好的写法.reveal {  color: red;
  left: 10px;
  top: 100px;
  visibility: visible;
}
element.classList.add(&#39;.reveal&#39;);
Copier après la connexion

Parce que le CSS className peut devenir un pont de communication entre CSS et JS. Dans le cycle de vie de la page, JS peut ajouter et supprimer le className de l'élément à volonté. Le style défini par className est dans le code CSS. A tout moment, les styles en CSS peuvent être modifiés sans avoir à mettre à jour JS. JS ne doit pas manipuler les styles directement afin de maintenir un couplage lâche avec CSS.

Il existe une situation où l'utilisation de l'attribut style est acceptable : lorsque vous devez positionner un élément sur la page par rapport à un autre élément ou repositionner la page entière. Ce calcul ne peut pas être effectué en CSS, vous pouvez donc utiliser style.top, style.left, style.bottom et style.rght pour positionner correctement l'élément. Définissez les attributs par défaut de cet élément en CSS, et modifiez ces valeurs par défaut en Javascript.

Compte tenu de la situation actuelle dans laquelle le front-end a écrit HTML et JS ensemble, je ne parlerai pas de la pratique consistant à séparer les deux dans le livre original. Mais, après avoir dit toutes ces absurdités, rappelez-vous ceci : la prévisibilité conduit à des tests et un développement plus rapides, et savoir (plutôt que deviner) par où commencer le débogage des bogues permettra de résoudre le problème plus rapidement et la qualité globale de votre code sera meilleure.

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

Comment utiliser JS pour passer par référence et passer par valeur

Comment créer un nœud Interface .js

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quatre outils de programmation assistés par IA recommandés Quatre outils de programmation assistés par IA recommandés Apr 22, 2024 pm 05:34 PM

Cet outil de programmation assistée par l'IA a mis au jour un grand nombre d'outils de programmation assistée par l'IA utiles à cette étape de développement rapide de l'IA. Les outils de programmation assistés par l'IA peuvent améliorer l'efficacité du développement, améliorer la qualité du code et réduire les taux de bogues. Ils constituent des assistants importants dans le processus de développement logiciel moderne. Aujourd'hui, Dayao partagera avec vous 4 outils de programmation assistés par l'IA (et tous prennent en charge le langage C#). J'espère que cela sera utile à tout le monde. https://github.com/YSGStudyHards/DotNetGuide1.GitHubCopilotGitHubCopilot est un assistant de codage IA qui vous aide à écrire du code plus rapidement et avec moins d'effort, afin que vous puissiez vous concentrer davantage sur la résolution de problèmes et la collaboration. Git

Quel programmeur IA est le meilleur ? Explorez le potentiel de Devin, Tongyi Lingma et de l'agent SWE Quel programmeur IA est le meilleur ? Explorez le potentiel de Devin, Tongyi Lingma et de l'agent SWE Apr 07, 2024 am 09:10 AM

Le 3 mars 2022, moins d'un mois après la naissance de Devin, le premier programmeur d'IA au monde, l'équipe NLP de l'Université de Princeton a développé un agent SWE pour programmeur d'IA open source. Il exploite le modèle GPT-4 pour résoudre automatiquement les problèmes dans les référentiels GitHub. Les performances de l'agent SWE sur l'ensemble de tests du banc SWE sont similaires à celles de Devin, prenant en moyenne 93 secondes et résolvant 12,29 % des problèmes. En interagissant avec un terminal dédié, SWE-agent peut ouvrir et rechercher le contenu des fichiers, utiliser la vérification automatique de la syntaxe, modifier des lignes spécifiques et écrire et exécuter des tests. (Remarque : le contenu ci-dessus est un léger ajustement du contenu original, mais les informations clés du texte original sont conservées et ne dépassent pas la limite de mots spécifiée.) SWE-A

Apprenez à développer des applications mobiles en utilisant le langage Go Apprenez à développer des applications mobiles en utilisant le langage Go Mar 28, 2024 pm 10:00 PM

Didacticiel d'application mobile de développement du langage Go Alors que le marché des applications mobiles continue de croître, de plus en plus de développeurs commencent à explorer comment utiliser le langage Go pour développer des applications mobiles. En tant que langage de programmation simple et efficace, le langage Go a également montré un fort potentiel dans le développement d'applications mobiles. Cet article présentera en détail comment utiliser le langage Go pour développer des applications mobiles et joindra des exemples de code spécifiques pour aider les lecteurs à démarrer rapidement et à commencer à développer leurs propres applications mobiles. 1. Préparation Avant de commencer, nous devons préparer l'environnement et les outils de développement. tête

Résumé des cinq bibliothèques du langage Go les plus populaires : outils essentiels au développement Résumé des cinq bibliothèques du langage Go les plus populaires : outils essentiels au développement Feb 22, 2024 pm 02:33 PM

Résumé des cinq bibliothèques du langage Go les plus populaires : des outils essentiels au développement, nécessitant des exemples de code spécifiques. Depuis sa naissance, le langage Go a fait l'objet d'une attention et d'une application généralisées. En tant que langage de programmation émergent, efficace et concis, le développement rapide de Go est indissociable du support de riches bibliothèques open source. Cet article présentera les cinq bibliothèques de langage Go les plus populaires. Ces bibliothèques jouent un rôle essentiel dans le développement Go et offrent aux développeurs des fonctions puissantes et une expérience de développement pratique. Parallèlement, afin de mieux comprendre les usages et les fonctions de ces bibliothèques, nous les expliquerons avec des exemples de codes précis.

Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Mar 20, 2024 pm 06:56 PM

Cockpit est une interface graphique Web pour les serveurs Linux. Il est principalement destiné à faciliter la gestion des serveurs Linux pour les utilisateurs nouveaux/experts. Dans cet article, nous aborderons les modes d'accès à Cockpit et comment basculer l'accès administratif à Cockpit depuis CockpitWebUI. Sujets de contenu : Modes d'entrée du cockpit Trouver le mode d'accès actuel au cockpit Activer l'accès administratif au cockpit à partir de CockpitWebUI Désactiver l'accès administratif au cockpit à partir de CockpitWebUI Conclusion Modes d'entrée au cockpit Le cockpit dispose de deux modes d'accès : Accès restreint : il s'agit de la valeur par défaut pour le mode d'accès au cockpit. Dans ce mode d'accès vous ne pouvez pas accéder à l'internaute depuis le cockpit

Quelle distribution Linux est la meilleure pour le développement Android ? Quelle distribution Linux est la meilleure pour le développement Android ? Mar 14, 2024 pm 12:30 PM

Le développement d'Android est un travail chargé et passionnant, et le choix d'une distribution Linux adaptée au développement est particulièrement important. Parmi les nombreuses distributions Linux, laquelle est la plus adaptée au développement Android ? Cet article explorera ce problème sous plusieurs aspects et donnera des exemples de code spécifiques. Tout d’abord, jetons un coup d’œil à plusieurs distributions Linux actuellement populaires : Ubuntu, Fedora, Debian, CentOS, etc. Elles ont toutes leurs propres avantages et caractéristiques.

Comprendre VSCode : à quoi sert cet outil ? Comprendre VSCode : à quoi sert cet outil ? Mar 25, 2024 pm 03:06 PM

« Comprendre VSCode : à quoi sert cet outil ? » 》En tant que programmeur, que vous soyez débutant ou développeur expérimenté, vous ne pouvez pas vous passer de l'utilisation d'outils d'édition de code. Parmi les nombreux outils d'édition, Visual Studio Code (VSCode en abrégé) est très populaire parmi les développeurs en tant qu'éditeur de code open source, léger et puissant. Alors, à quoi sert exactement VSCode ? Cet article approfondira les fonctions et les utilisations de VSCode et fournira des exemples de code spécifiques pour aider les lecteurs.

PHP est-il front-end ou back-end dans le développement Web ? PHP est-il front-end ou back-end dans le développement Web ? Mar 24, 2024 pm 02:18 PM

PHP appartient au backend du développement Web. PHP est un langage de script côté serveur, principalement utilisé pour traiter la logique côté serveur et générer du contenu Web dynamique. Par rapport à la technologie front-end, PHP est davantage utilisé pour les opérations back-end telles que l'interaction avec les bases de données, le traitement des demandes des utilisateurs et la génération du contenu des pages. Ensuite, des exemples de code spécifiques seront utilisés pour illustrer l'application de PHP dans le développement back-end. Tout d'abord, regardons un exemple de code PHP simple pour se connecter à une base de données et interroger des données :

See all articles