您是否探索過網格自動流的力量:密集?當與隨機生成的值(限制在設定範圍內)結合使用時,您可以使用網格列和網格行屬性來創建很酷的基於網格的藝術。讓我們開始吧!
首先,讓我們建立一個基本網格結構:
main { display: grid; grid-auto-flow: dense; grid-template-columns: repeat(auto-fill, minmax(var(--w, 4cqi), 1fr)); }
- display: grid: 建立 CSS 網格佈局。
- grid-auto-flow: 密集:透過重新定位項目以最小化空白空間來自動填滿網格中的間隙。
- grid-template-columns:定義響應式列佈局。這裡,自動建立列來填入可用空間(自動填入),每個列的最小寬度為 --w (預設為 4cqi),最大寬度為 1fr。
此時,--w未定義,因此使用預設值(4cqi)。初始網格如下圖所示:
接下來,我們將用一堆 -節點填滿網格。當我們使用 JavaScript 渲染它們時,我們為每個節點添加 2 個變數:
- --gc:要跨越的列數。
- --gr:要跨越的行數。
以下是我們如何在 JavaScript 中產生隨機值:
const random = (min, max) => Math.random() * (max - min) + min const column = () => `--gc:${Math.floor(random(0, 4))};` const row = () => `--gr:${Math.floor(random(0, 3))};`
在 CSS 中,我們應用這些自訂屬性:
b { background: oklch(var(--l) var(--c) var(--h) / var(--a)); grid-column: span var(--gc); grid-row: span var(--gr, 1); }
我們也可以使用一個小輔助方法在 oklch 中加入一些隨機顏色:
const color = () => `--l:${ random(0, 100)}%;--c:${ random(0, 0.5)};--h:${ random(0, 60)};--a:${ random(0.2, 1)};`
現在我們得到:
謝謝你,grid-auto-flow:密集!
為了讓事情更加動態,讓我們加入旋轉和縮放等轉換:
b { rotate: var(--r); scale: var(--s); }
在 JavaScript 中,我們產生隨機轉換值:
const transform = () => `--r:${random(-2, 3)}deg; --s:${random(0.8, 1.2)};`
我們來看看:
太棒了!現在,為了更進一步,讓我們添加一些很酷的 SVG 濾鏡。
在 JavaScript 中,我們新增了另一個小輔助方法來為每個 節點選擇一個隨機過濾器:
const filter = () => `--url:url(#${ [ "pencilTexture", "pencilTexture2", "pencilTexture3", "pencilTexture4", ][Math.floor(random(0, 4))] });`
這給了我們:
現在,透過簡單地調整 --w 屬性和元素數量,我們就可以產生截然不同的藝術作品:
或:
我們也可以在顏色方法中調整開始值和停止值:
示範
這是一個 Codepen 演示。我在圖稿下方新增了控件,因此您可以輕鬆調整屬性:
以上是使用 CSS 網格和 SVG 濾鏡進行藝術創作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

這是我們在形式可訪問性上進行的小型系列中的第三篇文章。如果您錯過了第二篇文章,請查看“以:focus-visible的管理用戶焦點”。在

本教程演示了使用智能表單框架創建外觀專業的JavaScript表單(注意:不再可用)。 儘管框架本身不可用,但原理和技術仍然與其他形式的建築商相關。

CSS盒子陰影和輪廓屬性獲得了主題。讓我們查看一些在真實主題中起作用的示例,以及我們必須將這些樣式應用於WordPress塊和元素的選項。

Svelte Transition API提供了一種使組件輸入或離開文檔(包括自定義Svelte Transitions)時動畫組件的方法。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版
好用的JavaScript開發工具

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