Maison >interface Web >tutoriel CSS >Savez-vous pourquoi CSS3 ne sera pas suivi de CSS4 ?

Savez-vous pourquoi CSS3 ne sera pas suivi de CSS4 ?

无忌哥哥
无忌哥哥original
2018-07-12 09:42:334384parcourir

Pour faire simple, à partir de CSS3, la spécification CSS a été divisée en plusieurs modules (modules) pour des mises à niveau individuelles, ou de nouvelles exigences ont été établies en tant que nouveau module et standardisées. Par conséquent, il n'y aura plus à l'avenir de changements dits majeurs de numéro de version tels que CSS4 et CSS5, mais seulement une certaine transition CSS au niveau du module.

Avant l'introduction de la modularité

Selon le groupe de travail CSS, il n'y avait pas de notion de versions dans l'histoire du CSS, seulement la notion de "niveau". Par exemple, CSS3 est en fait CSS niveau 3, CSS2 est CSS niveau 2 et CSS niveau 1 est bien sûr CSS1. Chaque niveau s'appuie sur le précédent.

Tout le monde sait que CSS1 est obsolète depuis longtemps. CSS2 est en fait fondamentalement obsolète. Cependant, CSS1, CSS2 (et CSS2.1) étaient à l’époque des spécifications vastes et complètes. De plus, lorsque CSS2 est devenu le standard final, l’étape CR n’avait pas encore été définie dans le processus de spécification du W3C.

Plus tard, le W3C a encore amélioré le processus de développement des spécifications, exigeant que chaque spécification passe par les cinq étapes suivantes :

1 Draft de travail

(WD, Working Draft) <.>

2. Projet de travail final

(LC/LCWD, projet de travail du dernier appel)

3. Recommandation du candidat

(CR, recommandation du candidat)

4. Recommandation proposée

(PR, Recommandation proposée)

5. Norme recommandée

(REC, Recommandation)

En raison de la Le CSS2 original n'est pas passé par l'étape CR, il y a donc de nombreux problèmes. Le groupe de travail CSS a été submergé de « corrections de bugs » sans fin. En conséquence, ils ont décidé de faire une révision de CSS2, qui est CSS2.1 (CSS Level 2 Revision 1).

En d’autres termes, CSS2.1 n’est en fait qu’une version révisée de CSS2, sans changements substantiels. Certains contenus de CSS2 ont été considérés comme immatures par le groupe de travail CSS et ont été supprimés de CSS2.1. Ces contenus supprimés sont considérés comme étant ramenés à l'étape CR du processus - ce qui équivaut à la nécessité d'un « rembobinage ». (Plus tard, ces contenus ont été essentiellement révisés et complétés dans CSS niveau 3 sous la forme de modules CSS.)

CSS2.1 et les spécifications CSS précédentes ont écrit tout le contenu dans un seul document. À mesure que les fonctionnalités CSS deviennent de plus en plus complexes, les spécifications CSS deviennent de plus en plus longues. La version PDF de CSS2.1 compte 430 pages. Cela entraîne de grands inconvénients pour les errata et les mises à niveau ultérieures. Parce que la progression de la mise à niveau des différentes parties du document ne peut pas être forcée à être cohérente.

Le groupe de travail CSS a donc décidé de suivre la voie modulaire à partir de CSS2.1. C'est-à-dire que le contenu qui doit être mis à niveau est séparé en modules indépendants et que de nouvelles exigences sont également établies en tant que nouveaux modules. Depuis, CSS est entré au niveau 3.

Après l'introduction de la modularité

Après que CSS ait emprunté la voie modulaire, il existe trois types de modules, et leur dénomination est très remarquable.

Modules originaux de CSS Niveau 2 : Sélecteur, Couleur, Valeurs et unités, Arrière-plans et Bordures, etc. Ce sont tous des modules séparés de la spécification CSS d'origine. La dénomination de ces modules commencera au niveau 3 au début, comme les sélecteurs niveau 3, les arrière-plans CSS et les bordures niveau 3, car ils démarrent tous sur la base du niveau CSS 2.

Nouveaux modules : mise en page multi-colonnes, transitions, boîte flexible, transformations, etc. sont tous des modules nouvellement ajoutés. Des fonctionnalités similaires n'existaient pas en CSS auparavant. Par conséquent, leur dénomination commencera à partir du niveau 1, comme CSS Transitions Level 1, CSS Flexible Box Module Level 1.

Bien sûr, il y a aussi des éléments que CSS2.1 a supprimés de CSS2. Comme mentionné précédemment, "le contenu en CSS2 supprimé par CSS2.1 est considéré comme étant retombé au stade CR", et la plupart du contenu sera "réincarné" sous la forme de CSS niveau 3. Une fois qu'ils entreront dans le stade CR , ils le feront. Il remplacera le contenu correspondant précédent et deviendra la nouvelle norme.

OK, l'avancement de la spécification de l'un des modules ci-dessus du stade WD au stade REC signifie soit la naissance d'un nouveau module CSS, soit la renaissance d'un ancien module CSS !

J'espère que l'image suivante pourra expliquer la dénomination des modules CSS de manière plus intuitive :



Savez-vous pourquoi CSS3 ne sera pas suivi de CSS4 ?Les modules auront également le niveau 4 ou supérieur

Les CSS au niveau 3 n'évolueront pas vers le niveau 4 en raison de la stratégie de "modularisation" adoptée. Pour cette raison, CSS ne verra théoriquement jamais CSS4. Cependant, un certain module en CSS peut atteindre le niveau 4 ou supérieur. Par exemple, CSS Color Module a commencé son parcours de mise à niveau vers le niveau 4 (https://www.w3.org/TR/css-color-4/).

Voici ce que dit l'instantané CSS 2017 :

Il n'y a pas de niveau CSS 4. Les modules indépendants peuvent atteindre le niveau 4 ou au-delà, mais CSS le langage n'a plus de niveaux (« CSS niveau 3. " car un terme est utilisé uniquement pour le différencier des versions monolithiques précédentes.)

Il n'y a pas de niveau CSS 4. Les modules indépendants peuvent atteindre le niveau 4 ou supérieur, mais le langage CSS n'aura plus ce niveau. (« CSS niveau 3 » en tant que concept sert simplement à le distinguer de la version précédente, vaste et complète.)

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:
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