国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

CSS實現(xiàn)8種炫酷按鈕

張春雷 / 1959人閱讀

在各種UI組件庫大行其道的今天,大家已經(jīng)很少自己用CSS去實現(xiàn)一些效果了,久而久之CSS的水平也越來越退步,所以有空還是得練練。今天給大家分享8種炫酷按鈕的CSS實現(xiàn)。

1. 3D按鈕1

現(xiàn)在的主流是扁平化的設(shè)計,擬物化的設(shè)計比較少見了,所以我們僅從技術(shù)角度去分析如何實現(xiàn)這個3D按鈕(文中只列出各種實現(xiàn)的關(guān)鍵代碼,完整代碼請參考CodePen)。

該按鈕的立體效果主要由按鈕多出的左、下兩個側(cè)面襯托出來,我們可以使用box-shadow模擬出這兩個側(cè)面:

HTML:

CSS:

.button-3d-1{
  position: relative;
  background: orangered;
  border: none;
  color: white;
  padding: 15px 24px;
  font-size: 1.4rem;
  outline: none;
  box-shadow: -6px 6px 0 hsl(16, 100%, 30%);
}

效果:

加了box-shadow之后整體形狀有點像了,但是立方體的左上和右下確缺了一塊。通過觀察我們發(fā)現(xiàn),缺的這兩塊是三角形的,所以如果我們能構(gòu)造兩個三角形補到這兩個角上就行了。用CSS畫三角形對大家來說應(yīng)該是基本操作了,如果還有同學(xué)不知道,下面的動畫很好的解釋了原理(代碼參考 Triangle):

我們使用::before::after偽元素來分別繪制左上、右下的兩個三角形,并通過絕對定位將它們固定到兩個角落:

CSS:

.button-3d-1::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  top: 0;
  left: -6px;
  border: 6px solid transparent;
  border-right: 6px solid hsl(16, 100%, 30%);
  border-left-width: 0px;
}

.button-3d-1::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  bottom: -6px;
  right: 0;
  border: 6px solid transparent;
  border-top: 6px solid hsl(16, 100%, 30%);
  border-bottom-width: 0px;
}

接下來,我們需要實現(xiàn)點擊時按鈕被按下的效果,思路是點擊時將按鈕正面向左下角移動,同時減少box-shadow的偏移量以達(dá)到按鈕底部固定不動的效果:

CSS:

.button-3d-1:active {
  background: hsl(16, 100%, 40%);
  top: 3px;
  left: -3px;
  box-shadow: -3px 3px 0 hsl(16, 100%, 30%);
}

最后,我們需要重新計算左上、右下兩個三角形的尺寸和位置,以適應(yīng)按下后上下缺口的變小:

CSS:

.button-3d-1:active::before {
  border: 3px solid transparent;
  border-right: 3px solid hsl(16, 100%, 30%);
  border-left-width: 0px;
  left: -3px;
}

.button-3d-1:active::after {
  border: 3px solid transparent;
  border-top: 3px solid hsl(16, 100%, 30%);
  border-bottom-width: 0px;
  bottom: -3px;
}
最終效果:CodePen 3D Button 1 2. 3D按鈕2

對于這種圓柱形的按鈕,思路和上面矩形3D的按鈕類似,也是通過box-shadow構(gòu)造側(cè)面呈現(xiàn)立體感。為了使效果更加真實,側(cè)面的顏色呈現(xiàn)漸變效果,越往下顏色越深,因此我們可以通過疊加多層box-shadow來實現(xiàn):

HTML:

CSS:

.button-3d-2{
  position: relative;
  background: #ecd300;
  background: radial-gradient(hsl(54, 100%, 50%), hsl(54, 100%, 40%));
  font-size: 1.4rem;
  text-shadow: 0 -1px 0 #c3af07;
  color: white;
  border: 1px solid hsl(54, 100%, 20%);
  border-radius: 100%;
  height: 120px;
  width: 120px;
  z-index: 4;
  outline: none;

  box-shadow: inset 0 1px 0 hsl(54, 100%, 50%),
              0 2px 0 hsl(54, 100%, 20%),
              0 3px 0 hsl(54, 100%, 18%),
              0 4px 0 hsl(54, 100%, 16%),
              0 5px 0 hsl(54, 100%, 14%),
              0 6px 0 hsl(54, 100%, 12%),
              0 7px 0 hsl(54, 100%, 10%),
              0 8px 0 hsl(54, 100%, 8%),
              0 9px 0 hsl(54, 100%, 6%);
}

當(dāng)點擊按鈕的時候,通過下移按鈕和減少box-shadow的層數(shù)來實現(xiàn)按鈕被按下的效果:

CSS:

.button-3d-2:active{
  ...
  top: 2px;
  box-shadow: inset 0 1px 0 hsl(54, 100%, 50%),
              0 2px 0 hsl(54, 100%, 16%),
              0 3px 0 hsl(54, 100%, 14%),
              0 4px 0 hsl(54, 100%, 12%),
              0 5px 0 hsl(54, 100%, 10%),
              0 6px 0 hsl(54, 100%, 8%),
              0 7px 0 hsl(54, 100%, 6%);
}
最終效果:CodePen 3D Button 2 3. 漸變按鈕1

提到漸變色大家一般都會想到background-image屬性可以設(shè)置為linear-gradient以呈現(xiàn)漸變色的背景,事實上linear-gradient的類型屬于的一種,所以凡是可以使用圖片的屬性都可以用linear-gradient代替,包括border-image。實現(xiàn)這個按鈕的關(guān)鍵在于實現(xiàn)一個漸變色和邊框,而且當(dāng)鼠標(biāo)懸浮的時候邊框和背景融為一體。

首先,我們實現(xiàn)漸變色的邊框。

HTML:

CSS:

.gradient-button-1{
  position: relative;
  z-index: 1;
  display: inline-block;
  padding: 20px 40px;
  font-size: 1.4rem;
  box-sizing: border-box;
  background-color: #e7eef1;
  color: orangered;
  border:solid 10px transparent;
  border-image: linear-gradient(to top right, orangered, yellow);
}

效果:

很奇怪,只有四個頂點有圖像。這是因為border-image-slice默認(rèn)為100%,所以導(dǎo)致四條邊線上并沒有分配背景圖像。border-image-slice的用法參考 MDN,簡而言之就是用四條(上下、左右各兩條平行線,想象一下九宮格火鍋。。)將圖片切割成9塊,在border的對應(yīng)區(qū)域顯示對應(yīng)的圖像切片,而border-image-slice的值就是那四條線的偏移量。這下大家應(yīng)該能理解偏移量為100%的時候只有四個頂點上才有圖片了吧。

所以我們需要調(diào)整border-image-slice的值,鑒于border-image-sourcelinear-gradient,我們需要將border-image-slice的值設(shè)置為1(表示四條線的偏移量都為1px)才能顯示連續(xù)的漸變色背景:

CSS:

.gradient-button-1{
  ...
  border-image-slice: 1;
}

最后,我們只需要在鼠標(biāo)懸浮的時候用漸變色填充按鈕內(nèi)部就行了,此處有兩種實現(xiàn),用 background-image 或者 將border-image-slice 設(shè)置為 fill (表示填充border中間的區(qū)域):

CSS:

.gradient-button-1:hover{
  color: white;
  background-image: linear-gradient(to top right, orangered, yellow);

  /* 或者 */

  border-image-slice: 1 fill;
}
最終效果:CodePen Gradient Button 1 4. 漸變按鈕2

與上一種按鈕類似,只不過顏色是逐漸變透明,實現(xiàn)也類似:

HTML:

CSS:

.gradient-button-2{
  ...
  border:solid 4px transparent;
  border-image: linear-gradient(to right, orangered, transparent);
  border-image-slice: 1;
}

.gradient-button-2:hover{
  color: white;
  background-image: linear-gradient(to right, orangered, transparent);
  border-right: none;
}
注意點:當(dāng)hover的時候需要設(shè)置 border-right: none,否則右側(cè)邊框無法呈現(xiàn)消失的狀態(tài)。
最終效果:CodePen Gradient Button 2 5. 動畫按鈕1

給按鈕加上一個動態(tài)背景的思路是:先找一個可以repeat的背景圖(可以去 siteorigin 生成),然后使用keyframe自定義一段動畫,當(dāng)鼠標(biāo)懸浮在按鈕上的時候運行該動畫:

HTML:

CSS:

.animated-button-1{
  position: relative;
  display: inline-block;
  padding:  20px 40px;
  font-size: 1.4rem;
  background-color: #00b3b4;
  background-image: url("wave.png");
  background-size: 46px 26px;
  border: 1px solid #555;
  color: white;
  transition: all ease 0.3s;
}

.animated-button-1:hover{
  animation: waving 2s linear infinite;
}

@keyframes waving{
  from{
    background-position: 0 0;
  }
  to{
    background-position: 46px 0;
  }
}
注意點:background-position 水平方向的值需要等于背景圖片的寬度或其整數(shù)倍,這樣動畫循環(huán)播放的時候首尾才能平穩(wěn)過渡。
最終效果:CodePen Animted Button 1 6. 動畫按鈕2

該按鈕的實現(xiàn)思路是:用 ::after 偽元素創(chuàng)建右側(cè)的箭頭,使用絕對定位固定在按鈕右側(cè),靜止?fàn)顟B(tài)下通過設(shè)置opacity: 0隱藏,當(dāng)鼠標(biāo)懸浮時,增大按鈕的padding-right,同時增加箭頭的不透明度,并將其位置往左移動:

HTML:

CSS:

.animated-button-2{
  position: relative;
  padding:  20px 40px;
  font-size: 1.4rem;
  background-color: #00b3b4;
  background-size: 46px 26px;
  border: 1px solid #555;  
  color: white;
  transition: all ease 0.3s;
}

.animated-button-2::after{
  position: absolute;
  top: 50%;
  right: 0.6em;
  transform: translateY(-50%);
  content: "?";
  font-size: 1.2em;
  transition: all ease 0.3s;
  opacity: 0;
}

.animated-button-2:hover{
  padding: 20px 60px 20px 20px;
}

.animated-button-2:hover::after{
  right: 1.2em;
  opacity: 1;
}
最終效果:CodePen Animated Button 2 7. 開關(guān)按鈕1

這算是一個挺常見的開關(guān)按鈕,它的實現(xiàn)思路是:

通過一個checkbox記錄開關(guān)的狀態(tài),并隱藏該checkbox;

使用一個 作為整個按鈕容器,并通過 for 屬性與checkbox關(guān)聯(lián),這樣點擊按鈕的任何地方都能改變checkbox的狀態(tài);

使用一個 作為按鈕可視的部分,并作為 checkbox 的相鄰元素,這樣通過 checkbox的偽類選擇器 :checked 和相鄰選擇器 + 選中 并顯示不同狀態(tài)下的內(nèi)容。

HTML:

CSS:

.toggle1{
  vertical-align: top;
  width: 80px;
  display: block;
  margin: 100px auto;
}

.toggle1-input{
  display: none;
}

.toggle1-button{
  position: relative;
  display: inline-block;
  font-size: 1rem;
  line-height: 20px;
  text-transform: uppercase;
  background-color: #f2395a;
  border: 1px solid #f2395a;
  color: white;
  width: 100%;
  height: 30px;
  transition: all 0.3s ease;
  cursor: pointer;
}


.toggle1-button::before{
  position: absolute;
  top: 5px;
  left: 38px;
  content: "off";
  display: inline-block;
  height: 20px;
  padding: 0 3px;
  background: white;
  color: #f2395a;
  transition: all 0.3s ease;
}

.toggle1-input:checked + .toggle1-button{
 background: #00b3b4; 
 border-color: #00b3b4;
}

.toggle1-input:checked + .toggle1-button::before{
  left: 5px;
  content: "on";
  color: #00b3b4;
}
注意點:for 屬性的作用;:checked 偽類的使用;+ 相鄰選擇器的使用。
最終效果:CodePen Switch Button 1 8. 開關(guān)按鈕2

與開關(guān)按鈕1類似,動畫效果上更簡單,只要切換顏色就行了:

HTML:

CSS:

.toggle2{
  font-size: 0.8rem;
  display: inline-block;
  vertical-align: top;
  margin: 0 15px 0 0;
}

.toggle2-input{
  display: none;
}

.toggle2-button{
  position: relative;
  display: inline-block;
  line-height: 20px;
  text-transform: uppercase;
  background: white;
  color: #aaa;
  border: 1px solid #ccc;
  padding: 5px 10px 5px 30px;
  transition: all 0.3s ease;
  cursor: pointer;
}

.toggle2-button::before{
  position: absolute;
  top: 10px;
  left: 10px;
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #ccc;
  content: "";
  transition: all 0.3s ease;
  border-radius: 50%;
}

.toggle2-input:checked + .toggle2-button{
  background: #00b3b4;
  border-color: #00b3b4;
  color: white;
}

.toggle2-input:checked + .toggle2-button::before{
  background: white;
}
最終效果:CodePen Switch Button 2
本文參考:https://youtu.be/pmKyG3NBY_k

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/116154.html

相關(guān)文章

  • CSS實現(xiàn)8炫酷按鈕

    在各種UI組件庫大行其道的今天,大家已經(jīng)很少自己用CSS去實現(xiàn)一些效果了,久而久之CSS的水平也越來越退步,所以有空還是得練練。今天給大家分享8種炫酷按鈕的CSS實現(xiàn)。 1. 3D按鈕1 showImg(https://segmentfault.com/img/remote/1460000019943760?w=640&h=192); 現(xiàn)在的主流是扁平化的設(shè)計,擬物化的設(shè)計比較少見了,所以我們僅從...

    fai1017 評論0 收藏0
  • 利用CSS變量實現(xiàn)炫酷的懸浮效果

    摘要:最近,我從網(wǎng)站上發(fā)現(xiàn)以一個好玩兒的懸停動畫,也有了些自己的靈感。用包裹文本,以避免顯示在按鈕的上方。將和初始化為,當(dāng)用戶懸停在按鈕上時,將其改為。 最近,我從 Grover網(wǎng)站上發(fā)現(xiàn)以一個好玩兒的懸停動畫,也有了些自己的靈感。這個動畫是將鼠標(biāo)移動到訂閱按鈕上移動光標(biāo)會顯示相應(yīng)的彩色漸變。這個想法很簡單,但是它能使這個按鈕脫穎而出,人們一下子就注意到它了,增加了點擊的概率。showImg...

    laoLiueizo 評論0 收藏0
  • 利用CSS變量實現(xiàn)炫酷的懸浮效果

    摘要:最近,我從網(wǎng)站上發(fā)現(xiàn)以一個好玩兒的懸停動畫,也有了些自己的靈感。用包裹文本,以避免顯示在按鈕的上方。將和初始化為,當(dāng)用戶懸停在按鈕上時,將其改為。 最近,我從 Grover網(wǎng)站上發(fā)現(xiàn)以一個好玩兒的懸停動畫,也有了些自己的靈感。這個動畫是將鼠標(biāo)移動到訂閱按鈕上移動光標(biāo)會顯示相應(yīng)的彩色漸變。這個想法很簡單,但是它能使這個按鈕脫穎而出,人們一下子就注意到它了,增加了點擊的概率。showImg...

    vincent_xyb 評論0 收藏0
  • CSS3實現(xiàn)炫酷的切片式圖片輪播效果

    摘要:今天我們學(xué)習(xí)如何使用創(chuàng)建一個炫酷的圖片輪播組件。我們還可以改變小圓圈的顏色并添加一個陰影效果。圖片的容器將占據(jù)所有的寬度,并且絕對定位。當(dāng)然通過這個效果我們還可以延伸出更多的切片效果,例如效果二效果三效果四要獲取以上輪播效果的代碼可以 今天我們學(xué)習(xí)如何使用CSS創(chuàng)建一個炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標(biāo)簽元素(label)來切換背景圖像和動畫效果。核心是使用與標(biāo)簽關(guān)聯(lián)的...

    EdwardUp 評論0 收藏0
  • CSS3實現(xiàn)炫酷的切片式圖片輪播效果

    摘要:今天我們學(xué)習(xí)如何使用創(chuàng)建一個炫酷的圖片輪播組件。我們還可以改變小圓圈的顏色并添加一個陰影效果。圖片的容器將占據(jù)所有的寬度,并且絕對定位。當(dāng)然通過這個效果我們還可以延伸出更多的切片效果,例如效果二效果三效果四要獲取以上輪播效果的代碼可以 今天我們學(xué)習(xí)如何使用CSS創(chuàng)建一個炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標(biāo)簽元素(label)來切換背景圖像和動畫效果。核心是使用與標(biāo)簽關(guān)聯(lián)的...

    jackzou 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<