文中我們對(duì)CSS超炫加載動(dòng)畫(huà)設(shè)計(jì)、實(shí)現(xiàn)與實(shí)例進(jìn)行了講解與說(shuō)明,通過(guò)學(xué)習(xí)可知使用CSS提供的animation屬性及偽元素等可以實(shí)現(xiàn)精美的CSS動(dòng)畫(huà)效果的設(shè)計(jì)與開(kāi)發(fā)。本文我們將繼續(xù)介紹CSS在Web頁(yè)面元素設(shè)計(jì)中的應(yīng)用。
純CSS實(shí)現(xiàn)開(kāi)關(guān)元素設(shè)計(jì)
本例我們使用CSS完成開(kāi)關(guān)的設(shè)計(jì),主要要求是在點(diǎn)擊開(kāi)關(guān)時(shí)開(kāi)關(guān)標(biāo)識(shí)顏色需要改變,另外需要體現(xiàn)出元素點(diǎn)擊前與點(diǎn)擊后的動(dòng)態(tài)變化與立體效果。本例最終設(shè)計(jì)呈現(xiàn)效果描述如下圖所示:
開(kāi)關(guān)按鈕實(shí)現(xiàn)效果展示
要實(shí)現(xiàn)如上圖所示的開(kāi)關(guān)按鈕效果,需要針對(duì)元素改變鼠標(biāo)點(diǎn)擊前后的CSS樣式,因?yàn)橹皇褂肅SS實(shí)現(xiàn),我們選擇本身具有點(diǎn)擊屬性的INPUT元素。因此還需要考慮對(duì)INPUT元素外觀進(jìn)行設(shè)置,其設(shè)置也主要是依托于CSS選擇器及相關(guān)屬性的設(shè)置。
CSS選擇器及屬性設(shè)置
另一方面本例中出現(xiàn)的開(kāi)關(guān)標(biāo)志,主要使用第三方字體庫(kù)提供的圖標(biāo)實(shí)現(xiàn),因此需要對(duì)font相關(guān)屬性及CSS外部link方法有所學(xué)習(xí)掌握。本例所使用字體如下所示:
字體圖標(biāo)
在明確基本思路之后,我們可以使用submine進(jìn)行代碼編寫(xiě),主要編寫(xiě)步驟如下:
1、鏈接字體樣式
本例使用如上圖所示提供的on圖標(biāo),即Font Awesome圖標(biāo)字體庫(kù)和CSS框架,因此需要外部鏈接或者下載相應(yīng)CSS文件,這里我們選擇外部鏈接,通過(guò)使用CSS提供的link,實(shí)現(xiàn)代碼如下:
字體鏈接
鏈接完成之后我們?cè)谠O(shè)置字體時(shí)可直接使用FontAwesome字體,其中on圖標(biāo)對(duì)應(yīng)的編碼為f011。
2、定義頁(yè)面內(nèi)容
本例頁(yè)面內(nèi)容主要使用input元素checkbox屬性進(jìn)行按鈕設(shè)置。因此頁(yè)面內(nèi)容部分定義如下所示:
頁(yè)面主體部分
3、定義checkbox樣式
在完成頁(yè)面元素添加之后就需要對(duì)頁(yè)面元素進(jìn)行CSS樣式的設(shè)置,本例通過(guò)元素加type屬性作為選擇器,選擇指定元素并進(jìn)行樣式設(shè)置。代碼如下:
checkbox屬性設(shè)置
checkbox屬性設(shè)置描述如上圖所示,設(shè)置效果如下:
checkbox屬性效果
4、input添加checked、after等樣式
為進(jìn)一步實(shí)現(xiàn)點(diǎn)擊效果切換及圖標(biāo)按鈕的效果,需要對(duì)check狀態(tài)及after偽元素進(jìn)行CSS樣式的設(shè)置。其中after為元素主要用于在上圖中添加on開(kāi)關(guān)圖標(biāo)。實(shí)現(xiàn)代碼描述如下:
after偽元素選擇器及樣式設(shè)置
after偽元素選擇器及樣式設(shè)置如上圖所示,主要完成content內(nèi)容即on圖標(biāo)設(shè)置,字體選擇、字體顏色及字體大小設(shè)置,設(shè)置完成預(yù)覽效果如下:
after為元素設(shè)置效果
要實(shí)現(xiàn)點(diǎn)擊效果就需要在點(diǎn)擊之后對(duì)input元素樣式進(jìn)行設(shè)置,因此我們使用checked作為選擇器對(duì)該狀態(tài)下input樣式進(jìn)行設(shè)置。設(shè)置代碼如下所示:
checked狀態(tài)CSS設(shè)置
checked狀態(tài)CSS設(shè)置如上圖所示,我們只對(duì)box-shadow陰影進(jìn)行設(shè)置,通過(guò)陰影變化實(shí)現(xiàn)按鈕動(dòng)態(tài)效果。
5、點(diǎn)擊之后on圖標(biāo)顏色變化
點(diǎn)擊之后on圖標(biāo)顏色變化主要通過(guò)對(duì)input[type="checkbox"]:checked,進(jìn)一步使用after偽元素定義字體顏色實(shí)現(xiàn)。實(shí)現(xiàn)代碼如下所示:
on圖標(biāo)(字體)顏色改變
通過(guò)使用該選擇器,會(huì)在input點(diǎn)擊之后,on字體顏色變?yōu)榧t色。以上給出了input按鈕效果實(shí)現(xiàn)的基本思路與部分核心實(shí)現(xiàn)代碼。如需完整案例代碼請(qǐng)關(guān)注并私信作者。
本頭條號(hào)長(zhǎng)期關(guān)注編程資訊分享;編程課程、素材、代碼分享及編程培訓(xùn)。如果您對(duì)以上方面有興趣或代碼錯(cuò)誤、建議與意見(jiàn),可在評(píng)論區(qū)回復(fù)。更多程序設(shè)計(jì)相關(guān)教程及實(shí)例分享,期待大家關(guān)注與閱讀!
過(guò)一段時(shí)間的醞釀,我決定繼續(xù)開(kāi)啟頭條文章的發(fā)布。
1. 將自己平常工作學(xué)習(xí)中的素材積累,分享在頭條號(hào)。既能加深記憶,又能為大家?guī)?lái)分享。
2. 標(biāo)題為零基礎(chǔ)HTML的意思很簡(jiǎn)單,我希望讓HTML這個(gè)前端語(yǔ)言變成每一位網(wǎng)友都熟知的語(yǔ)言。因?yàn)樗鋵?shí)并不復(fù)雜,甚至可以說(shuō)它就是計(jì)算機(jī)語(yǔ)言中的“美圖秀秀”
3. 如有想加深學(xué)習(xí)進(jìn)度的小伙伴,請(qǐng)私信我。
廢話不說(shuō)了,開(kāi)始 零基礎(chǔ)HTML素材積累01 CSS HOVER的7個(gè)按鈕
CSS hover 樣式很簡(jiǎn)單,但是想創(chuàng)造出有意思、實(shí)用、有創(chuàng)意性的特效是很考驗(yàn)設(shè)計(jì)師的創(chuàng)意能力,所以設(shè)計(jì)達(dá)人每隔一段時(shí)間都會(huì)分享一些與鼠標(biāo)點(diǎn)擊、懸停的相關(guān)特效,以便大家獲得更好的創(chuàng)造靈感。
今天我們整理了10組網(wǎng)頁(yè)按鈕的點(diǎn)擊與懸停效果,每組都有不同的特色以及創(chuàng)意性,下面達(dá)人將特效錄制成 GIF 動(dòng)圖,方便大家在線觀看
查看演示: 私信九弓子:css hover (獲取源碼演示鏈接)
們都見(jiàn)過(guò)它們,它們保護(hù)我們的眼睛免受所有光線的傷害。 這些是暗模式按鈕,這里是如何在 HTML、CSS 和 JS 中創(chuàng)建自己的按鈕!
我們要做的第一件事是創(chuàng)建 HTML 文件。 我正在使用引導(dǎo)程序使按鈕看起來(lái)不錯(cuò)。 我要做的第一件事是將引導(dǎo)程序鏈接到我的 HTML 文件,這樣我就可以訪問(wèn)所有按鈕。
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-0evHe/X+R7YkIZDRvuzKMRqM+OrBnVFBL6DOitfPri4tjfHxaWutUpFmBp4vmVor" crossorigin="anonymous"><title>Dark mode</title></head><body></body></html>
這是樣板 HTML 代碼。 現(xiàn)在我將添加按鈕并鏈接 css 樣式表。 如果您正在跟進(jìn),請(qǐng)?jiān)谂c您的 HTML 文件相同的目錄中創(chuàng)建一個(gè) style.css 文件。
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="style.css"><link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-0evHe/X+R7YkIZDRvuzKMRqM+OrBnVFBL6DOitfPri4tjfHxaWutUpFmBp4vmVor" crossorigin="anonymous"><title>Dark mode</title></head><body><button type="button" class="btn btn-dark">Dark Mode</button></body></html>
我使用了引導(dǎo) btn-dark 類,它只是一個(gè)簡(jiǎn)單的深色按鈕。
現(xiàn)在為 css。 我將創(chuàng)建一個(gè) .dark 類,但我知道我們還沒(méi)有分配它。 那將適用于黑暗模式。
.dark {background-color: black;}
現(xiàn)在,我們將添加一些 javascript。 我們不會(huì)制作新文件,因?yàn)樗粫?huì)那么多。 我將首先給按鈕一個(gè)“按鈕”類,然后從那里開(kāi)始工作。我將添加一個(gè)事件偵聽(tīng)器,然后在單擊時(shí),我將切換 HTML 主體類 dark 。然后我將向主體添加一個(gè) ID,以便我們可以 使用 JavaScript 選擇它。然后我將更改文本和按鈕顏色,以便我們可以來(lái)回切換。
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="style.css"><link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-0evHe/X+R7YkIZDRvuzKMRqM+OrBnVFBL6DOitfPri4tjfHxaWutUpFmBp4vmVor" crossorigin="anonymous"><title>Dark mode</title></head><body id="body" class=""><button type="button" class="btn btn-dark" class="button">Dark Mode</button><script>let button = document.querySelector('button');let body = document.getElementById('body');button.addEventListener('click', () => {body.classList.toggle('dark');if(body.classList.contains('dark')) {button.style.backgroundColor = "white";button.innerHTML = "Light Mode"button.style.color = "black";} else {button.style.backgroundColor = "black";button.innerHTML = "Dark Mode"button.style.color = "white";}});</script></body></html>
僅此而已! 謝謝閱讀。 如果你喜歡,請(qǐng)關(guān)注!
*請(qǐng)認(rèn)真填寫(xiě)需求信息,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。