目录
来自其他语言的随机化
为什么我在乎CSS中的随机值?
模拟随机掷骰子
此技术有一些明显的缺点
首页 web前端 css教程 CSS中有随机数吗?

CSS中有随机数吗?

Apr 15, 2025 am 09:37 AM

Are There Random Numbers in CSS?

CSS赋予网页动态布局和交互能力,但作为一种静态语言,一旦值被设定,便无法更改。因此,随机性的概念在此并不适用。运行时生成随机数是JavaScript的领域,而非CSS。或者说,并非完全如此?如果加入一点用户交互,我们实际上可以在CSS中生成一定程度的随机性。让我们来看一看!

来自其他语言的随机化

正如Robin Rendle在CSS-Tricks的一篇文章中所解释的那样,可以使用CSS变量来实现某种程度的“动态随机化”。但这些方案并非完全基于CSS,因为它们需要JavaScript来更新CSS变量,使其包含新的随机值。

我们可以使用Sass或Less等预处理器来生成随机值,但是一旦CSS代码被编译和导出,这些值就固定了,随机性也就消失了。正如Jake Albaugh所解释的:

Sass中的random就像随机选择故事中主角的名字一样。只有在编写时才是随机的,它不会改变。

— jake albaugh (@jake_albaugh) 2016年12月29日

为什么我在乎CSS中的随机值?

过去,我开发过一些简单的纯CSS应用程序,例如琐事游戏、Simon游戏和魔术技巧。但我想要做一些更复杂的事情。关于创建这些纯CSS片段的有效性、实用性或可行性的讨论,我将留待以后再进行。

基于一些棋盘游戏可以用有限状态机(FSM)表示的前提,它们可以用HTML和CSS来表示。所以我开始开发一个蛇梯游戏(也称为Chutes and Ladders)。这是一个简单的游戏。目标是通过避开蛇并尝试向上爬梯子,将棋子从起点推进到棋盘的终点。

这个项目似乎可行,但我缺少一样东西:掷骰子

掷骰子(以及抛硬币)普遍被认为是随机化的。你掷骰子或抛硬币,每次都会得到一个未知的值。

模拟随机掷骰子

我打算叠加带有标签的图层,并使用CSS动画来“旋转”并交换哪个图层位于顶部。就像这样:

模拟这种随机性的代码并不复杂,可以使用动画和不同的动画延迟来实现:

<code>/* 最高的z-index是骰子的面数 */
@keyframes changeOrder {
  from { z-index: 6; }
  to { z-index: 1; }
}

/* 所有标签都使用绝对定位重叠 */
label {
  animation: changeOrder 3s infinite linear;
  background: #ddd;
  cursor: pointer;
  display: block;
  left: 1rem;
  padding: 1rem;
  position: absolute;
  top: 1rem;
  user-select: none;
}

/* 负延迟,以便动画的所有部分都在运动 */
label:nth-of-type(1) { animation-delay: -0.0s; }
label:nth-of-type(2) { animation-delay: -0.5s; }
label:nth-of-type(3) { animation-delay: -1.0s; }
label:nth-of-type(4) { animation-delay: -1.5s; }
label:nth-of-type(5) { animation-delay: -2.0s; }
label:nth-of-type(6) { animation-delay: -2.5s; }</code>
登录后复制

动画速度已放慢,以便于交互(但仍然足够快,可以看出下面解释的障碍)。伪随机性也更清晰了。

但后来我遇到了一个障碍:我得到了随机数,但有时,即使我点击我的“骰子”,它也没有返回任何值。

我尝试增加动画时间,这似乎有所帮助,但我仍然遇到一些意外的值。

这时,我做了大多数开发人员在遇到无法仅通过在线搜索解决的障碍时所做的事情:我以StackOverflow问题的形式向其他开发人员寻求帮助。

幸运的是,总是有资源的Temani Afif提出了一个解释和一个解决方案。

简单来说,问题是浏览器只在鼠标按下时激活的元素与鼠标抬起时激活的元素相同时才会触发click/press事件。

由于旋转动画,鼠标按下时的顶部标签不是鼠标抬起时的顶部标签,除非我足够快或足够慢地让动画循环。这就是为什么增加动画时间会隐藏这些问题的原因。

解决方案是将“static”位置应用于打破堆叠上下文,并使用具有更高z-index的伪元素(如::before或::after)来占据其位置。这样,鼠标抬起时,活动标签将始终位于顶部。

<code>/* 活动标签将是静态的,并移出窗口 */
label:active {
  margin-left: 200%;
  position: static;
}

/* 标签的伪元素占据所有空间,并具有更高的z-index */
label:active::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  z-index: 10;
}</code>
登录后复制

以下是包含解决方案的代码,动画时间更快:

进行此更改后,剩下的唯一事情是创建一个小的界面来绘制一个假的骰子来点击,纯CSS蛇梯游戏就完成了。

此技术有一些明显的缺点

  • 需要用户输入:必须点击标签才能触发“随机数生成”。
  • 不能很好地扩展:它适用于小的值集,但对于大的范围来说很麻烦。
  • 它不是真正的随机,而是伪随机:计算机可以很容易地检测到在每个时刻将生成哪个值。

但另一方面,它是100%的CSS(不需要预处理器或其他外部帮助程序),并且对于人类用户来说,它看起来可以是100%随机的。

说到手……这种方法不仅可以用于随机数,还可以用于任何随机的东西。在这种情况下,我们用它来“随机”选择石头剪刀布游戏中电脑的选择:

以上是CSS中有随机数吗?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热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

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

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1673
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
静态表单提供商的比较 静态表单提供商的比较 Apr 16, 2025 am 11:20 AM

让我们尝试在这里造成一个术语:“静态表单提供商”。你带上html

使Sass更快的概念证明 使Sass更快的概念证明 Apr 16, 2025 am 10:38 AM

在一个新项目开始时,Sass汇编发生在眼睛的眨眼中。感觉很棒,尤其是当它与browsersync配对时,它重新加载

每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom 每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom Apr 17, 2025 am 10:55 AM

在本周的平台新闻综述中,Chrome引入了一个用于加载的新属性,Web开发人员的可访问性规范以及BBC Move

带有HTML对话框元素的一些动手 带有HTML对话框元素的一些动手 Apr 16, 2025 am 11:33 AM

这是我第一次查看HTML元素。我已经意识到了一段时间,但是尚未将其旋转。它很酷,

纸张形式 纸张形式 Apr 16, 2025 am 11:24 AM

购买或建造是技术的经典辩论。自己构建东西可能会感觉更便宜,因为您的信用卡账单上没有订单项,但是

'订阅播客”链接应在哪里? '订阅播客”链接应在哪里? Apr 16, 2025 pm 12:04 PM

有一段时间,iTunes是播客中的大狗,因此,如果您将“订阅播客”链接到喜欢:

托管您自己的非JavaScript分析的选项 托管您自己的非JavaScript分析的选项 Apr 15, 2025 am 11:09 AM

有很多分析平台可帮助您跟踪网站上的访问者和使用数据。也许最著名的是Google Analytics(广泛使用)

See all articles