搜索
首页web前端css教程CSS中有随机数吗?

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
'订阅播客”链接应在哪里?'订阅播客”链接应在哪里?Apr 16, 2025 pm 12:04 PM

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

浏览器引擎多样性浏览器引擎多样性Apr 16, 2025 pm 12:02 PM

当他们在2013年去Chrome时,我们失去了歌剧。与Edge今年早些时候也进行了同样的交易。迈克·泰勒(Mike Taylor)称这些变化为“减少

网络共享的UX注意事项网络共享的UX注意事项Apr 16, 2025 am 11:59 AM

从垃圾点击诱饵网站到大多数出版物的最多,共享按钮长期以来一直无处不在。然而,这些

每周平台新闻:Apple部署网络组件,渐进的HTML渲染,自托管关键资源每周平台新闻:Apple部署网络组件,渐进的HTML渲染,自托管关键资源Apr 16, 2025 am 11:55 AM

在本周的综述中,Apple进入Web组件,Instagram如何插入脚本以及一些思考的食物,以进行自托管关键资源。

git Pathspecs以及如何使用它们git Pathspecs以及如何使用它们Apr 16, 2025 am 11:53 AM

当我查看GIT命令的文档时,我注意到其中许多人都有选择。我最初以为这只是一个

产品图像的彩色拾取器产品图像的彩色拾取器Apr 16, 2025 am 11:49 AM

听起来有点像一个困难的问题,不是吗?我们经常没有成千上万种颜色的产品镜头,以便我们可以随身携带。我们也不是

黑暗模式与React和Themeprovider切换黑暗模式与React和Themeprovider切换Apr 16, 2025 am 11:46 AM

我喜欢网站具有“暗模式”选项时。黑暗模式使我更容易阅读网页,并帮助我的眼睛更放松。许多网站,包括

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

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

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脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

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