首頁 >web前端 >css教學 >CSS網頁按鈕設計:創造各種酷炫的按鈕樣式

CSS網頁按鈕設計:創造各種酷炫的按鈕樣式

WBOY
WBOY原創
2023-11-18 10:28:101737瀏覽

CSS網頁按鈕設計:創造各種酷炫的按鈕樣式

CSS網頁按鈕設計:建立各種酷炫的按鈕樣式,需要具體程式碼範例

在網頁設計中,按鈕是一個非常重要的元素,因為它不僅是用戶和網站互動的紐帶,還能夠增加整體視覺效果和用戶體驗。而一個好的按鈕樣式不僅要有吸引人的外觀,還需要考慮到一些功能細節,例如點擊效果、懸停效果等等。本文將為大家分享一些CSS按鈕設計的技巧和酷炫的樣式,同時提供程式碼範例,希望能夠幫助大家更好地設計按鈕,為網站和應用程式增加更多的創意。

一、基本的CSS按鈕

首先,我們來看看最基本的CSS按鈕樣式:

HTML程式碼:

<button class="btn">Click me</button>  

CSS樣式:

.btn {
  background-color: #4CAF50;
  border: none;
  color: white;
  padding: 10px 20px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  margin: 4px 2px;
  cursor: pointer;
}

.btn:hover {
  background-color: #3e8e41;
}

這個按鈕有綠色背景,白色文字和圓角邊框。當滑鼠懸浮在按鈕上時,背景色變為深綠色,實現了簡單的懸停效果。這個按鈕樣式基本上可以套用到大多數場景。

二、3D立體效果按鈕

下面我們來建立一個3D立體效果的按鈕:

HTML程式碼:

<button class="btn-3d">Click me</button>

CSS樣式:

.btn-3d {
    border: none;
    color: #fff;
    font-size: 25px;
    line-height: 1;
    margin: 20px;
    padding: 10px 20px;
    position: relative;
    text-align: center;
    text-shadow: rgba(0,0,0,.4) 1px 1px;
    transform-style: preserve-3d;
    transition: all .3s ease-out;
    background: linear-gradient(to bottom, #556270 0%,#616161 100%);
    background-color: #556270;
}

.btn-3d:before,
.btn-3d:after {
    border: none;
    content: '';
    position: absolute;
    top: calc(50% - 2px);
    left: 0;
    height: 4px;
    width: 100%;
    transform-style: preserve-3d;
    transition: all .3s ease-out;
}

.btn-3d:before {
    background: #BD3F32;
    transform: translateZ(-1px);
    box-shadow: 0 0 8px rgba(189,63,50,.7);
}

.btn-3d:after {
    background: #3F7FBC;
    transform-origin: left;
    transform: rotateY(90deg) translateZ(-1px);
    box-shadow: 0 0 8px rgba(63,127,188,.7);
}

.btn-3d:hover {
    background: linear-gradient(to bottom, #BD3F32 0%,#616161 100%);
    transform: translateZ(-6px);
    text-shadow: none;
    box-shadow: 0 0 8px rgba(0,0,0,.5);
}

.btn-3d:hover:before {
    transform: translateZ(-13px) rotateY(60deg);
}

.btn-3d:hover:after {
    transform: rotateY(-60deg) translateZ(-13px);
    transition-delay: .05s;
}

這個按鈕樣式有明顯的3D立體外觀效果和hover狀態時的平移/旋轉效果,不僅給用戶帶來了視覺上的衝擊,也增加了用戶體驗感。

三、背景變化按鈕

下面這個按鈕樣式透過背景色的漸變變化,在視覺上為使用者提供了更好的提示:

HTML程式碼:

<button class="btn-change">Click me</button>

CSS樣式:

.btn-change {
    cursor: pointer;
    display: inline-block;
    margin: .5rem;
    padding: .75rem 1.5rem;
    position: relative;
    text-align: center;
    text-transform: uppercase;
}

.btn-change:before {
    border-right: 1px solid white;
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: skew(-15deg) scaleY(1.4);
    width: 0;
}

.btn-change:hover:before {
    width: 100%;
    transition: all .3s ease;
}

.btn-change:after {
    border-left: 1px solid white;
    content: "";
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    transform: skew(15deg) scaleY(1.4);
    width: 0;
}

.btn-change:hover:after {
    width: 100%;
    transition: all .3s ease;
    transition-delay: .15s;
}

這個按鈕樣式的特點是hover狀態下背景色變化得比較漸進,可以在視覺上更好地引導使用者。

四、鏤空效果按鈕

接下來,我們將建立一個非常酷的鏤空效果按鈕樣式:

HTML程式碼:

<button class="btn-void">Click me</button>

CSS樣式:

.btn-void {
    border: solid 2px #bada55;
    background: none;
    color: #bada55;
    font-size: 18px;
    font-weight: bold;
    padding: 12px 24px;
    position: relative;
    transition: all .35s;
    overflow: hidden;
}

.btn-void:before,
.btn-void:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #bada55;
    transition: all .35s;
}

.btn-void:before {
    height: 0%;
    width: 100%;
}

.btn-void:after {
    height: 100%;
    width: 0%;
}

.btn-void:hover,
.btn-void:focus,
.btn-void:active {
    border-color: #bada55;
    color: #fff;
}

.btn-void:hover:before,
.btn-void:focus:before,
.btn-void:active:before {
    height: 100%;
}

.btn-void:hover:after,
.btn-void:focus:after,
.btn-void:active:after {
    width: 100%;
}

這個按鈕樣式的特徵是hover狀態下,按鈕週邊出現了一個白邊框,並且按鈕內部的矩形形狀的區域變為白色,按鈕文字變為綠色。整體恢復時,有漸層的效果呈現。

五、載入中按鈕

最後,我們來看一個有載入狀態的按鈕樣式:

HTML程式碼:

<button class="btn-loading">Submit</button>

CSS樣式:

.btn-loading {
  background-color: #4CAF50;
  border: none;
  color: white;
  padding: 10px 20px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  margin: 4px 2px;
  cursor: pointer;
  position: relative;
}

.btn-loading:after {
  content: "";
  position: absolute;
  top:50%;
  left: 50%;
  border: 6px solid #e6e6e6;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  margin-left: -25px;
  margin-top: -25px;
  border-top-color: #3498db;
  animation: spin 2s linear infinite;
  display: none;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.btn-loading.loading:after {
  display: block;
}

這個按鈕樣式的特點是,在點擊提交按鈕後,按鈕內容會被隱藏,並出現一個旋轉的動畫,提示用戶正在加載中,整體效果比較直觀。

總結

透過以上五個按鈕樣式的介紹,我們可以清晰的看到,一個好的按鈕不僅需要吸引人的視覺效果,還需要注意到一些功能細節,例如hover狀態下的變化、點擊後的互動等等。本文提供的按鈕樣式都是基於CSS編寫的,可以在實際專案中很方便的應用。大家在寫網頁時,可以多關註一些特殊效果的實現,打造更符合自己需求的按鈕。

以上是CSS網頁按鈕設計:創造各種酷炫的按鈕樣式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn