La création de jeux avec CSS, les cases à cocher et les techniques de bouton radio est notoire (ou largement connue). Mais il s'avère que d'autres éléments basés sur la saisie des utilisateurs peuvent également être habilement utilisés et utilisés pour la gamification. Les développeurs ont créé de nombreux cas de jeu CSS très cool, qui sont basés sur :hover
pseudo-catégorie, et même des jeux basés sur la pseudo-catégorie :valid
.
Cependant, j'ai trouvé que les Pseudo-classes :target
semblent être sous-explorées dans ce domaine des compétences CSS. Après y avoir pensé, il s'agit d'une fonctionnalité CSS puissante sous-estimée: : Target nous permet de styliser n'importe quel élément en fonction du lien de saut sélectionné, ce qui signifie que le navigateur a une version simple du routage client intégré! Devenez des scientifiques fous et voyons où cela peut nous prendre.
AI invincible dans CSS
Ai-je connecté ces mots ensemble? Devrions-nous utiliser CSS frénétiquement jusqu'à ce que nous atteignions la singularité? Essayez de vaincre le jeu Tic Toe dans la feuille de style ci-dessous et décidez par vous-même.
Les feuilles de styles permettent parfois au jeu de se terminer par une égalité, vous avez donc au moins une doublure argentée.
Ne vous inquiétez pas! CSS n'est pas encore devenu Skynet. Comme tout astuce CSS, la règle de base pour déterminer si un jeu peut être mis en œuvre avec CSS est possible dans le nombre d'états de jeu . J'ai réalisé cela lorsque j'ai pu créer un solveur 4 × 4 Sudoku et j'ai constaté que la version 9 × 9 était presque impossible à mettre en œuvre. En effet, les astuces CSS dépendent finalement des sélecteurs qui répondent à l'entrée de l'utilisateur pour masquer et afficher l'état du jeu.
Si X passe en premier, Tic Toe a 5478 États juridiques qui peuvent être réalisés, et il existe un algorithme bien connu qui peut calculer le meilleur mouvement dans n'importe quel état juridique. Par conséquent, nous pouvons utiliser entièrement CSS pour implémenter les jeux Tic Toe.D'accord, comment le faire?
Dans un sens, nous ne craquons pas du tout CSS, mais en utilisant CSS comme volonté de Dieu: cacher, afficher et animer le contenu. "Smart" réside dans la façon dont HTML est généré. C'est comme un livre "Choisissez votre propre aventure" qui contient tous les états possibles du multivers tic-toe, avec des carrés vides reliant le meilleur mouvement suivant de l'ordinateur.
Nous utilisons une variante de l'algorithme minimax implémenté dans Ruby pour le générer. Saviez-vous que Codepen prend en charge HAML (prend en charge Ruby Blocks), et pouvons-nous l'utiliser secrètement comme un terrain de jeu Ruby? Maintenant tu sais.
Chaque État généré par notre HAML ressemble à celui-ci dans HTML:
<div> <svg><circle></circle></svg><a href="https://www.php.cn/link/320bc51fecc423dd893a420b42b9719a"> <div></div> </a> <svg><circle></circle></svg><svg><circle></circle></svg><div></div> <a href="https://www.php.cn/link/7259202cea475e0e98aa076037cc3f15"> <div></div> </a> <a href="https://www.php.cn/link/f514659f5c754f0cec51ea59a5e826ae"> <div></div> </a> <a href="https://www.php.cn/link/a23eabd0e013e2ef19cc27099204ea18"> <div></div> </a> <a href="https://www.php.cn/link/7a50f770e0e910d3beffd653f7c4197e"> <div></div> </a> </div>Avec juste une petite quantité de CSS étonnamment simple, nous pouvons utiliser le sélecteur
pour afficher uniquement l'état du jeu actuellement sélectionné. Nous ajouterons également une classe :target
aux mouvements historiques de l'ordinateur - afin que nous ne déclencherons que des animations d'écriture manuscrite dans les derniers mouvements de l'ordinateur. Cela nous donne l'impression de jouer à des jeux sur un tableau, et en réalité, nous sautions entre différentes parties du document. .c
<div> <svg><circle></circle></svg><a href="https://www.php.cn/link/320bc51fecc423dd893a420b42b9719a"> <div></div> </a> <svg><circle></circle></svg><svg><circle></circle></svg><div></div> <a href="https://www.php.cn/link/7259202cea475e0e98aa076037cc3f15"> <div></div> </a> <a href="https://www.php.cn/link/f514659f5c754f0cec51ea59a5e826ae"> <div></div> </a> <a href="https://www.php.cn/link/a23eabd0e013e2ef19cc27099204ea18"> <div></div> </a> <a href="https://www.php.cn/link/7a50f770e0e910d3beffd653f7c4197e"> <div></div> </a> </div>
Lors de la sélection du lien de saut en cliquant sur le carré vide, le :target
pseudo-classe affichera l'état du jeu mis à jour (.s
), et le jeu de réponse pré-calculé sur l'ordinateur apparaît de manière animée (.c
).
Veuillez noter la situation spéciale lorsque nous démarrons le jeu: Avant que l'utilisateur ne sélectionne un lien de saut, nous devons afficher la grille vide initiale. Le contenu du style n'est pas défini au début, donc une fois le lien de saut sélectionné, nous utilisons le sélecteur :target
pour masquer l'état initial. De même, si vous créez une expérience à l'aide de :body:has(:target) #---------
, vous devez rendre la vue initiale avant que l'utilisateur ne commence à interagir avec la page. :target
Je n'entrerai pas dans la profondeur des raisons pour lesquelles nous allons implémenter cela dans CSS, plutôt que d'utiliser une approche "plus facile" de JavaScript. C'est juste une façon amusante et éducative de repousser les limites du CSS. Par exemple, nous pouvons le faire en utilisant des astuces à cocher classiques - en fait, quelqu'un l'a fait.
y a-t-il quelque chose d'intéressant à utiliser
? Je pense oui, parce que: :target
- Nous pouvons enregistrer des jeux dans CSS! Accédez à l'URL à tout moment avec le signet de statut que vous avez laissé et retournez.
- Vous pouvez utiliser les boutons "Back" et "Forward" du navigateur comme commandes de jeu. Le mouvement peut être défait en revenant ou en le mouvement de lecture en allant de l'avant. Imaginez combiner avec des astuces à cocher pour créer un jeu avec un mécanicien de voyage dans le temps dans la tradition de Braid.
:target
- Partagez le statut de votre jeu. Cela a le potentiel de gagner des droits de présentation de type landus. Si vous parvenez à gagner ou à dessiner l'algorithme invincible CSS Tic Toe, vous pouvez montrer au monde vos réalisations en partageant des URL.
- Il s'agit d'un HTML complètement sémantique. Les astuces de case à cocher vous obligent à masquer les cases à cocher ou les boutons radio, donc c'est toujours une compétence et une bonne affaire douloureuse en matière d'accessibilité. Cette méthode est sans doute sans astuces, car nous utilisons simplement des liens de saut et des div et leurs styles. Cela peut même le faire - oserais-je dire - «plus facile» à offrir une expérience d'accès plus facile. Mais cela ne veut pas dire qu'il est facile d'accéder à la sortie de la boî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!

@KeyFramesAndcsstransitionsDiffeRinComplexity: @ KeyframesAllowsfordEtailedanimationSequences, tandis que les StransitionShandlesImpLestateChanges.USECSSTRANSITIONSFORHOVEFFECTSLILLOBUTTONCOLORCHANGES, et @ KeyframesFransintricateAralienslikeTatationSpinners.

Je sais, je sais: il y a une tonne d'options de système de gestion de contenu disponibles, et bien que je les teste plusieurs, aucun n'a vraiment été celui, y & # 039; savoir? Des modèles de tarification étranges, une personnalisation difficile, certains finissent même par devenir un tout

La liaison des fichiers CSS à HTML peut être réalisée en utilisant des éléments dans une partie de HTML. 1) Utilisez des balises pour relier les fichiers CSS locaux. 2) Plusieurs fichiers CSS peuvent être implémentés en ajoutant plusieurs balises. 3) Les fichiers CSS externes utilisent des liens URL absolus, tels que. 4) Assurez-vous que l'utilisation correcte des chemins de fichier et de l'ordre de chargement du fichier CSS et optimiser les performances peuvent utiliser le préprocesseur CSS pour fusionner les fichiers.

Le choix de Flexbox ou de la grille dépend des exigences de mise en page: 1) Flexbox convient aux dispositions unidimensionnelles, telles que la barre de navigation; 2) La grille convient aux dispositions bidimensionnelles, telles que les dispositions de magazines. Les deux peuvent être utilisés dans le projet pour améliorer l'effet de mise en page.

La meilleure façon d'inclure des fichiers CSS est d'utiliser des balises pour introduire des fichiers CSS externes dans la pièce HTML. 1. Utilisez des balises pour introduire des fichiers CSS externes, tels que. 2. Pour les petits ajustements, le CSS en ligne peut être utilisé, mais doit être utilisé avec prudence. 3. Les grands projets peuvent utiliser des préprocesseurs CSS tels que SASS ou moins pour importer d'autres fichiers CSS via @Import. 4. Pour les performances, les fichiers CSS doivent être fusionnés et CDN doit être utilisé et compressé à l'aide d'outils tels que CSSNANO.

Oui, vous émeuble-chouchoudion-dimensionnal, flexiblelayAndavigationMenus.2)

À quoi cela ressemble-t-il de refactor votre propre code? John Rhea sépare une vieille animation CSS qu'il a écrite et traverse le processus de réflexion pour l'optimiser.

CSSANIMATIONSARENOTINÉMENT HAUTS BUTREQUIREPRACTICIT ENCRIPTION DES PROFESSIONS DESPROPERTIES ET TROUVEMENT


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Version Mac de WebStorm
Outils de développement JavaScript utiles

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP
