搜尋
首頁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
模擬鼠標運動模擬鼠標運動Apr 22, 2025 am 11:45 AM

如果您曾經在現場演講或課程中必須顯示一個互動動畫,那麼您可能知道它並不總是那麼容易與您的幻燈片進行互動

通過Astro Action和Fuse.js為搜索提供動力通過Astro Action和Fuse.js為搜索提供動力Apr 22, 2025 am 11:41 AM

對於Astro,我們可以在構建過程中生成大部分網站,但是有一小部分服務器端代碼可以使用Fuse.js之類的搜索功能來處理搜索功能。在此演示中,我們將使用保險絲搜索一組個人“書籤”

未定義:第三個布爾值未定義:第三個布爾值Apr 22, 2025 am 11:38 AM

我想在我的一個項目中實現一條通知消息,類似於您在保存文檔時在Google文檔中看到的信息。換句話說,一個

捍衛三元聲明捍衛三元聲明Apr 22, 2025 am 11:25 AM

幾個月前,我正在使用黑客新聞(就像一個人一樣),並且遇到了一篇(現已刪除的)文章,內容涉及不使用if語句。如果您是這個想法的新手(就像我

使用網絡語音API進行多語言翻譯使用網絡語音API進行多語言翻譯Apr 22, 2025 am 11:23 AM

自科幻小說以來,我們就幻想著與我們交談的機器。今天這很普遍。即便如此,製造的技術

JetPack Gutenberg塊JetPack Gutenberg塊Apr 22, 2025 am 11:20 AM

我記得當古騰堡被釋放到核心時,因為那天我在WordCamp我們。現在已經過去了幾個月,所以我想我們越來越多的人

在VUE中創建可重複使用的分頁組件在VUE中創建可重複使用的分頁組件Apr 22, 2025 am 11:17 AM

大多數Web應用程序背後的想法是從數據庫中獲取數據,並以最佳方式將其呈現給用戶。當我們處理數據時

使用'盒子陰影”和剪輯路徑一起使用'盒子陰影”和剪輯路徑一起Apr 22, 2025 am 11:13 AM

讓我們在一個情況下做一些似乎有意義的事情的情況下逐步進行一些逐步,但是您仍然可以用CSS欺騙來完成它。在這個

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

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器