摘要:按鈕樣式的正確方式如果你正在建立一個網站或一個應用,你可能會用到按鈕,也許看起來像按鈕的鏈接。這是我們想要做的事情可應用于鏈接或按鈕的按鈕樣式我們希望有選擇地應用它,因為我們的頁面中會有其他鏈接和按鈕樣式。
按鈕樣式的正確方式
如果你正在建立一個網站或一個web應用,你可能會用到按鈕,也許看起來像按鈕的鏈接。不管怎樣,讓這些正常展示是很重要的。
在本教程中,我們將為和元素以及一個自定義.btn的CSS組件創建基本樣式。 你會在這個過程的每一步中找到一個演示頁面。
重置通常,網站或應用程序中可點擊事件的99.9%的元素應該是或元素。 如果您不確定在給定情況下使用什么元素:
如果它轉到其他網址或更改了網頁的大部分內容,請使用鏈接( ... )。
否則,請使用通用按鈕()。
使用正確的元素有幾個優點:它對搜索引擎友好(尤其是鏈接!),它適用于鍵盤導航,它提高了所有用戶的可訪問性。
盡管如此,開發人員很少使用元素。 在整個Web上,我們可以看到很多觸發JavaScript操作的按鈕,仔細檢查后發現它們是用 為什么元素如此不受待見? 知識點:許多開發人員不知道它(學習100+HTML元素需要一點時間)。 樣式上:附帶復雜的默認樣式,這可能很難實現自定義外觀。 幸運的是,樣式部分可以北修復! 我們最終得到的按鈕是類似普通文本的。 這種方法的缺點是,現在我們必須對所有按鈕進行樣式設置,否則用戶將無法識別它們。 另一個選擇是使用這種風格作為mixin(使用Sass或其他預處理器)并選擇性地應用它: 現在我們已經刪除了默認樣式,讓我們定義我們自己的按鈕樣式。 這是我們想要做的事情: 可應用于鏈接或按鈕的“按鈕”樣式; 我們希望有選擇地應用它,因為我們的頁面中會有其他鏈接和按鈕樣式。 這需要一個CSS組件。 CSS組件是一種風格或樣式集合,我們可以使用類來應用,通常在幾種不同類型的HTML元素之上。 您可能熟悉Bootstrap或Foundation等CSS框架中的這個概念。 我們將這個組件稱為.btn(就像Bootstrap一樣,但我們只設置顏色和大小,以保持簡單)。 以下是我們的按鈕組件的外觀: 你可能想知道為什么差別這么明顯。第二行按鈕看起來就不錯,誰不喜歡柔和的外觀? 很酷,你的按鈕看起來不錯,但是...用戶將與它進行交互,并且當按鈕的狀態改變時,他們需要視覺反饋。 瀏覽器為“focus”和“active”(即按下)狀態設置了默認樣式,但通過重置按鈕樣式我們已經刪除了其中的一些。 我們還希望為鼠標懸停設置樣式,總體而言,我們希望可見的樣式與我們的設計相匹配。 讓我們從以下主題開始:活動狀態,即按鈕或者鏈接被點擊: 我們可以更改按鈕的顏色,但我想為我們的鼠標懸停式樣保留這種效果: 現在讓我們添加一些焦點樣式。 您的網站或網絡應用程序的用戶可以使用鍵盤或虛擬鍵盤(在iOS和Android上)“”并激活表單域,按鈕,鏈接和其他交互元素。 對于一些用戶來說,它可以加速緩慢的交互,比如填寫表單。 對于其他人來說,使用鼠標或觸摸指針是不可能的或困難的。 他們依靠使用鍵盤或專用設備訪問網站。 在我見過的大多數Web項目中,設計師都指定了預期的鼠標移過樣式,但未指定焦點樣式。 我們應該做什么? 一個簡單的解決方案是重用:hover風格作為我們的focus風格: 一旦你有了這種可見的對焦風格(而不是之前?。?,你可能想要刪除瀏覽器的按鈕的默認樣式: 在這里嘗試一下; 如果您在桌面計算機上,請使用Tab和Shift + Tab鍵在按鈕之間導航: 還有一個棘手的問題。 在多個瀏覽器中,當您單擊鏈接或按鈕時,將應用兩個偽類: :active :focus 一旦停止按下鼠標按鈕或觸控板,“active”偽類就會停止應用。 但在某些瀏覽器中,focus樣式會一直保留,直到用戶點擊頁面上的其他內容為止。 在我的測試中,受影響的瀏覽器包括Chrome(66),Edge(16)和Firefox(60,僅用于鏈接)。 Safari(11.1)似乎更聰明并避免了這個問題。 我們可以使用新的: :focus-visible偽類(草稿規范)來解決此問題。 這個功能還沒有完全指定,但想法是瀏覽器只能在鍵盤或類似鍵盤的交互之后設置: :focus-visible,而不是點擊。 由于它尚未被瀏覽器實現,我們將不得不使用JavaScript實現,比如有些polyfill。 它在整個頁面上運行,并且僅在使用鍵盤時才將焦點可見的類設置為接收焦點的元素。 讓我們改變我們的樣式來解耦:hover和:focus樣式: 現在,在我們的頁面中包含focus-visible.js腳本后,它會為 一個更簡單的解決方案是只為focus-visible類聲明焦點樣式,但如果polyfill不是活動的(例如,如果我們的JS未能加載),則會中斷焦點樣式。 關注我的微信公眾號,更多優質文章定時推送 文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。 轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/113372.html/**
* Reset button styles.
* It takes a bit of work to achieve a neutral look.
*/
button {
padding: 0;
border: none;
font: inherit;
color: inherit;
background-color: transparent;
/* show a hand cursor on hover; some argue that we
should keep the default arrow cursor for buttons */
cursor: pointer;
}
@mixin button-reset {
padding: 0;
border: none;
font: inherit;
color: inherit;
background-color: transparent;
cursor: pointer;
}
.my-custom-button {
@include button-reset;
padding: 10px;
background-color: skyblue;
}
編寫一個“button”CSS組件
.btn {
/* default for
/* old-school "down" effect on clic + color tweak */
.btn:active {
transform: translateY(1px);
filter: saturate(150%);
}
/* inverse colors on mouse-over */
.btn:hover {
color: #9555af;
border-color: currentColor;
background-color: white;
}
/* inverse colors on mouse-over and focus */
.btn:hover,
.btn:focus {
color: #9555af;
border-color: currentColor;
background-color: white;
}
.btn {
/* ... */
/* all browsers: remove the default outline since
we are rolling our own focus styles */
outline: none;
}
/* Firefox: removes the inner border shown on focus */
.btn::-moz-focus-inner {
border: none;
}
/* inverse colors on hover */
.btn:hover {
color: #9050AA;
border-color: currentColor;
background-color: white;
}
/* make sure we have a visible focus ring */
.btn:focus {
outline: none;
box-shadow: 0 0 0 3px rgba(255, 105, 180, 0.5),
0 0 0 1.5px rgba(255, 105, 180, 0.5);
}
/* hide focus style if not from keyboard navigation */
.js-focus-visible .btn:focus:not(.focus-visible) {
box-shadow: none;
}
摘要:示例強制對中規定允許省略的閉合標簽,不允許省略閉合標簽。示例圖片強制禁止的取值為空。示例提交取消取消提交建議當使用進行表單提交時,如果條件允許,應使原生提交功能正常工作。示例建議模板代碼應以保證單個標簽語法的正確性為基本原則。 這段時間在整理前端部分代碼規范,初步想法是從HTML、CSS、Javascipt、項目文件目錄四部分是整理。之前已經整理完了CSS編碼規范,有興趣可以了解下 1...
摘要:多個標簽原生表單部件通用屬性默認這個布爾屬性允許您指定當頁面加載時元素應該自動具有輸入焦點,除非用戶覆蓋它,例如通過鍵入不同的控件。元素的名稱這是用于表單數據提交的。到目前為止,表單是最常見的攻擊媒介可能發生攻擊的地方。 表單介紹 HTML表單是用戶和web站點或應用程序之間交互的主要內容之一。它們允許用戶將數據發送到web站點。大多數情況下,數據被發送到web服務器,但是web頁面也...
閱讀 1197·2023-04-25 17:05
閱讀 3019·2021-11-19 09:40
閱讀 3573·2021-11-18 10:02
閱讀 1748·2021-09-23 11:45
閱讀 3030·2021-08-20 09:36
閱讀 2789·2021-08-13 15:07
閱讀 1141·2019-08-30 15:55
閱讀 2472·2019-08-30 14:11