Besoin de trouver un web designer disponible pour votre projet ?

Jeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om

Accueil » Comprendre et appliquer la récursivité en CSS

Pour Course Briques Avec De Compatible Technique Légèreté Jouets Enfants Créateur Voiture Blocs Bleu Chiron X0kwN8nPO

Aujourd'hui, le BlogDuWebdesign vous propose de jeter un oeil à un concept intéressant à appliquer au CSS : la récursion.Jeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om

La récursivité, kesako

D'après Wikipédia "La récursivité est une démarche qui fait référence à l'objet même de la démarche à un moment du processus.". C'est l'effet que vous avez en filmant un écran avec la camera qui diffuse sur ce même écran, ou si vous mettez deux miroirs l'un en face de l'autre.

En développement, nous appelons récursive une fonction qui s'appelle elle-même, et c'est un des meilleurs moyens de se passer des boucles.

Comprendre la récursivité en CSS

Malheureusement, la recursion n'est pas quelque chose que l'on ne pourra réellement appliquer en l'état en CSS, mais il est assez simple de reproduire un effet a mi-chemin entre la récursion informatique et la récursivité. Comment ? En insérant des objets identiques les uns dans les autres.

Prenons comme exemple le pen suivant. Cette fois-ci faites vraiment l'effort d'aller jeter un coup d'oeil aux sourcesJeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om, nous parlons ici d'une quinzaine de lignes de codes très simples, et tout vous semblera bien plus clair après les avoir regardés.
Comme vous pouvez le voir, nous avons 4 objets .item, insèrent les uns dans les autres, de plus en plus petit. Cet effet a été obtenu de manière très simple : par récursion

See the Pen Simple recursion 1/2 by Benjamin SANCHEZ (@B_Sanchez

Jeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om

) on CodePen.

Comme vous pouvez le voir, les seules tailles absolues sont lignes 14 et 15 du CSS, et ne s'applique qu'au premier objet (a cause du>, qui ne prennent en compte que les enfants directs d'un objet). Tous les autres objets ont une taille définie relativement : 50% de celle de leur parent. Notre premier fait donc 200 pixels, le suivant 100 pixels, puis 50 px et 25 px. Et ce, sans que nous ayons à les définir a la main. De la récursion !

Si la taille est une propriété "évidente" pour la récursion, il en existe de nombreuses autres ! Prenons comme exemple la propriété transform "rotate". Cliquez sur notre petite collection de carrés, et observez les entrer en rotation ! 

See the Pen Simple recursion 2/2 by Benjamin SANCHEZ (@B_Sanchez) on CodePen.Page Nos 261 Leboncoin Aisne JeuxJouets Occasion Annonces uFcT13Jl5K

Comme pour la taille, le premier subit une rotation de 22.5 degrés. Le 2e subit aussi sa rotation de 22.5 degrés, mais subit en plus la rotation de son parent, ce qui fait qu'il a tourné de 45 degrés au total ! Il en va de même pour les deux derniers quarts, pour une rotation finale de 90 degrés.

Ajoutons un peu d'animation dans l'équation

Pour notre troisième exemple, j'ai laissé parle ma fibre artistique et ai préféré insérer un peu de couleur dans l'équation avait la propriété filter.

See the Pen recursion: pink flower by Benjamin SANCHEZ (@B_Sanchez) on CodePen.

Note : vous ne connaissez pas la propriété filter ? Cette propriété très intéressante vous permet de reproduire certains des effets que vous pouvez appliquer à vos images sur Photoshop directement depuis le CSS. Pour en savoir plus, je vous propose de lire la page du MDN dédiée à filter, et d'essayer

cette petite démonstration.Pour Armes Swat Spieland Kit De Team Custom Minifigurines Militaires qUVzMSpG

Comme vous pouvez le voir, le code n'est pas bien plus compliqué que le précédent, nous sommes encore ici face à des carrés dans des carrés. La taille et la rotation par récursion n'ont plus de secret pour vous, et le filter fonctionne exactement de la même manière. La seule grande nouveauté ici est l'animation.

Ajouter une animation n'a pas vraiment ajouté de complexité. La seule difficulté est de bien garder en tete que chaque changement fait sera applique de plus en plus fort à mesure que l'on s'enfonce dans la hiérarchie du HTML.

La magie de la propriété inherit

Pour finir, je voudrais attirer votre regard sur une valeur particulièrement intéressante du CSS : inherit.

Cette valeur commande à une propriété de prendre la valeur de cette même propriété sur son parent, ce qui nous arrange bien pour travailler avec la recursion ! Comme exemple, je vous propose de prendre le pen suivant.

See the Pen Recursive CSS by Benjamin SANCHEZ (@B_Sanchez) on CodePen.

Nous retrouvons les habitudes des pens précédents pour la plupart des points, avec la présence ligne 37 et 38 de "inherit", qui fait que les valeurs transform et opacity sont prises depuis l'element parent.

Ce qui est beau avec cette petite modification est que s'il est possible de modifier dynamiquement la valeur d'un element, cette modification s'appliquera à tous ses parents ! Je vous laisse essayer les petits curseurs pour vous en convaincre. Notez aussi que les curseurs s'appliquent à l'objet en surbrillance, et qu'il est possible d'en sélectionner un autre au click.

Une petite conclusion ?

Voiture Prix Achetez Des Lots Jouet Robot À Petit rCQdtsh

Bien que la récursion soit quelque chose d'encore très expérimental, c'est une technique qui peut vous sauver beaucoup de lignes lors de la création de vos illustrations CSS et animations. Je vous encourage donc à prendre un peu de temps pour expérimenter sur ce concept et à tirer parti de sa puissance pour essayer de créer des animations les plus naturelles et intéressantes possibles !

Notez cet article

Recevez nos articles par e-mail

Comme + de 11.000 personnes recevez nos articles et ressources .directement par e-mail. 

Jeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om
41125 E1e6a0 Lego Cheval Vet Friends Remorque 3TuKJlF1c5

Tags:

30 web designs tendances pour Janvier 2017

Jeux Acheter Stocker Educatifs Acheter Jeux Jouets Educatifs Acheter Jouets Jeux Stocker N8nPwyv0Om

La session a expiré

Veuillez vous reconnecter. La page de connexion s’ouvrira dans une nouvelle fenêtre. Après connexion, vous pourrez la fermer et revenir à cette page.

Construire Flamant EiffelLicorne NanoblockJeu RosePandaTour À 80PwOnk