搜索
首页web前端css教程与:目标的时代旅行CSS

Time Travelling CSS With :target

利用CSS创建游戏,复选框和单选按钮技巧可谓臭名昭著(或广为人知)。但事实证明,其他基于用户输入的元素也可以被巧妙利用并用于游戏化。开发者们已经创造出许多非常酷炫的CSS游戏案例,这些案例分别基于:hover伪类,甚至还有基于:valid伪类的游戏。

然而,我发现:target伪类在这个CSS技巧领域似乎尚未得到充分探索。细想之下,这是一个被低估的强大CSS特性::target允许我们根据选定的跳转链接来设置任何元素的样式,这意味着浏览器内置了一个客户端路由的简易版本!让我们化身疯狂科学家,看看它能带我们去哪里。

CSS中无敌的AI

是我把这些词连在一起的吗?我们要不要疯狂地利用CSS,直到达到奇点?尝试击败下面的样式表中的井字棋游戏,自己决定吧。

样式表有时会允许游戏以平局结束,所以你至少还有一线希望。

不用担心!CSS还没有变成天网。像任何CSS技巧一样,确定一个游戏是否可以用CSS实现的经验法则是可能的游戏状态的数量。当我能够创建一个4×4数独求解器,却发现9×9版本几乎不可能实现时,我意识到了这一点。这是因为CSS技巧归根结底是基于对用户输入做出响应的选择器来隐藏和显示游戏状态。

如果X先走,井字棋有5478个可达到的合法状态,并且有一个著名的算法可以计算任何合法状态下的最佳移动。因此,我们可以完全用CSS来实现井字棋游戏。

好吧,怎么做?

从某种意义上说,我们根本没有在破解CSS,而是在按照上帝的旨意使用CSS:隐藏、显示和动画化内容。“智能”在于HTML的生成方式。这就像一本“自己选择冒险”的书,包含了井字棋多元宇宙中所有可能的状态,空方格链接到计算机的最佳下一步移动。

我们使用在Ruby中实现的minimax算法的变体来生成它。你知道CodePen支持HAML(支持Ruby块),我们可以秘密地将它用作Ruby游乐场吗?现在你知道啦。

我们的HAML生成的每个状态在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>

只需少量令人惊讶的简单的CSS,我们就可以使用:target选择器仅显示当前选定的游戏状态。我们还将添加一个.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>

当通过点击空方格选择跳转链接时,:target伪类将显示更新后的游戏状态(.s),样式设置为计算机的预先计算的响应以动画方式出现(.c)。

请注意我们开始游戏时的特殊情况:在用户选择任何跳转链接之前,我们需要显示初始的空网格。开始时没有用:target设置样式的内容,因此一旦选择跳转链接,我们就使用:body:has(:target) #---------选择器隐藏初始状态。类似地,如果您使用:target创建实验,则需要在用户开始与页面交互之前呈现初始视图。

总结

我不会深入探讨为什么我们要在CSS中实现这一点,而不是使用JavaScript的“更容易”的方法。这仅仅是推动CSS边界的一种乐趣和教育方式。例如,我们可以使用经典的复选框技巧来实现这一点——事实上,有人已经做到了。

使用:target有什么有趣之处吗?我认为是的,因为:

  • 我们可以保存CSS中的游戏! 随时用你离开时的状态书签访问URL并返回。
  • 可以使用浏览器的“后退”和“前进”按钮作为游戏控件。可以通过返回来撤消移动,或者通过前进重放移动。想象一下将:target与复选框技巧结合起来,按照《Braid》的传统创建一个具有时间旅行机制的游戏。
  • 分享你的游戏状态。 这有可能获得类似Wordle的炫耀权利。如果你设法在无敌的CSS井字棋算法中获胜或打平,你可以通过分享URL向世界展示你的成就。
  • 它是完全语义化的HTML。 复选框技巧要求你隐藏复选框或单选按钮,因此在可访问性方面它总是一种技巧和痛苦的讨价还价。这种方法可以说是没有技巧,因为我们只是在使用跳转链接和div及其样式。这甚至可能使它——我敢说——“更容易”提供更易于访问的体验。但这并不是说它开箱即用就易于访问。

以上是与:目标的时代旅行CSS的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
@KeyFrames vs CSS过渡:有什么区别?@KeyFrames vs CSS过渡:有什么区别?May 14, 2025 am 12:01 AM

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

使用页面CMS进行静态站点内容管理使用页面CMS进行静态站点内容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的内容管理系统选项可用,而我进行了几个测试,但实际上没有一个是一个,y&#039;知道吗?怪异的定价模型,艰难的自定义,有些甚至最终成为整个&

链接HTML中CSS文件的最终指南链接HTML中CSS文件的最终指南May 13, 2025 am 12:02 AM

链接CSS文件到HTML可以通过在HTML的部分使用元素实现。1)使用标签链接本地CSS文件。2)多个CSS文件可通过添加多个标签实现。3)外部CSS文件使用绝对URL链接,如。4)确保正确使用文件路径和CSS文件加载顺序,优化性能可使用CSS预处理器合并文件。

CSS Flexbox与网格:全面评论CSS Flexbox与网格:全面评论May 12, 2025 am 12:01 AM

选择Flexbox还是Grid取决于布局需求:1)Flexbox适用于一维布局,如导航栏;2)Grid适合二维布局,如杂志式布局。两者在项目中可结合使用,提升布局效果。

如何包括CSS文件:方法和最佳实践如何包括CSS文件:方法和最佳实践May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用标签在HTML的部分引入外部CSS文件。1.使用标签引入外部CSS文件,如。2.对于小型调整,可以使用内联CSS,但应谨慎使用。3.大型项目可使用CSS预处理器如Sass或Less,通过@import导入其他CSS文件。4.为了性能,应合并CSS文件并使用CDN,同时使用工具如CSSNano进行压缩。

Flexbox vs Grid:我应该学习两者吗?Flexbox vs Grid:我应该学习两者吗?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

轨道力学(或我如何优化CSS KeyFrames动画)轨道力学(或我如何优化CSS KeyFrames动画)May 09, 2025 am 09:57 AM

重构自己的代码看起来是什么样的?约翰·瑞亚(John Rhea)挑选了他写的一个旧的CSS动画,并介绍了优化它的思维过程。

CSS动画:很难创建它们吗?CSS动画:很难创建它们吗?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具