登入表單最佳做法

使用跨平台瀏覽器功能,建立安全、無障礙且易於使用的登入表單。

如果使用者需要登入您的網站,則良好的登入表單設計至關重要。對於連線不佳、使用行動裝置、急忙或處於壓力下的使用者來說,這一點尤其重要。設計不良的登入表單會導致跳出率偏高。每個跳出事件都可能代表使用者流失和不滿,而不僅是錯失登入機會。

以下是簡單的登入表單範例,其中展示了所有最佳做法:

檢查清單

使用有意義的 HTML

使用為工作建立的元素:<form><label><button>。這些標記可啟用內建瀏覽器功能、改善無障礙功能,並為標記新增意義。

使用 <form>

您可能會想要將輸入內容納入 <div>,並僅透過 JavaScript 處理輸入資料提交作業。一般建議使用一般的舊 <form> 元素。這樣一來,螢幕閱讀器和其他輔助裝置就能存取您的網站,您也能啟用各種內建的瀏覽器功能,為舊版瀏覽器建立基本功能登入機制,即使 JavaScript 失敗也能正常運作。

使用 <label>

如要標示輸入內容,請使用 <label>

<label for="email">Email</label>
<input id="email" …>

原因有二:

  • 輕觸或點選標籤可將焦點移至輸入內容。使用標籤的 for 屬性與輸入內容的 nameid,將標籤與輸入內容建立關聯。
  • 當標籤或標籤的輸入內容獲得焦點時,螢幕閱讀器會朗讀標籤文字。

請勿使用預留位置做為輸入標籤。使用者開始輸入文字後,很可能會忘記輸入內容的目的,尤其是在分心時 (「我要輸入電子郵件地址、電話號碼還是帳戶 ID?」)。預留位置還有許多其他潛在問題:如果您不相信,請參閱「不要使用預留位置屬性」和「表單欄位中的預留位置有害」。

建議您將標籤放在輸入內容上方。這可讓行動版和電腦版的設計保持一致,根據 Google AI 研究,使用者就能更快掃描。您會看到全寬標籤和輸入框,而且不需要調整標籤和輸入框的寬度,以便配合標籤文字。

螢幕截圖:顯示表單輸入標籤在行動裝置上的顯示位置:輸入框旁邊和上方。
如果標籤和輸入寬度皆在同一行,會受到限制。

在行動裝置上開啟 label-position Glitch,親自查看。

使用 <button>

使用 <button> 建立按鈕!按鈕元素可提供無障礙行為和內建表單提交功能,而且還能輕鬆設定樣式。沒有使用 <div> 或其他偽裝成按鈕的元素。

請確認提交按鈕會顯示其功能。例如「建立帳戶」或「登入」,而非「提交」或「開始」

確認成功提交表單

協助密碼管理員瞭解已提交表單。有兩種做法可以設定:

  • 前往其他頁面。
  • 使用 History.pushState()History.replaceState() 模擬導覽,並移除密碼表單。

使用 XMLHttpRequestfetch 要求時,請務必在回應中回報登入成功,並透過將表單從 DOM 中移除,以及向使用者指出成功,來處理這項要求。

使用者輕觸或點選「Sign in」按鈕後,建議您停用該按鈕。許多使用者會多次點選按鈕,即使是速度快且回應迅速的網站也不例外。這會導致互動速度變慢,並增加伺服器負載。

反之,請勿在等待使用者輸入內容時停用表單提交功能。舉例來說,如果使用者尚未輸入客戶 PIN 碼,請勿停用「Sign in」按鈕。使用者可能會在表單中遺漏某些項目,然後嘗試重複點選 (已停用)「Sign in」按鈕,並認為按鈕無法正常運作。如果您必須停用表單提交功能,請至少向使用者說明點選停用按鈕後會發生的情況。

不要重複輸入

有些網站會強制使用者輸入電子郵件地址或密碼兩次。這樣可以減少少數使用者遇到的錯誤,但會導致「所有」使用者執行額外工作,並提高放棄率。在瀏覽器自動填入電子郵件地址或建議強式密碼的情況下,詢問兩次也毫無意義。建議您讓使用者確認電子郵件地址 (您還是需要這麼做),並在必要時讓他們輕鬆重設密碼。

充分運用元素屬性

這裡的神奇魔法正是誕生的! 瀏覽器內建多項實用功能,可使用輸入元素屬性。

將密碼設為私密,但讓使用者可視需要查看密碼

密碼輸入應使用 type="password" 來隱藏密碼文字,並協助瀏覽器瞭解輸入的是密碼。(請注意,瀏覽器會使用各種技巧來瞭解輸入角色,並決定是否要提供密碼儲存選項)。

您應該新增「顯示密碼」切換按鈕,讓使用者檢查自己輸入的文字。別忘了新增「忘記密碼」連結。請參閱「啟用密碼顯示功能」。

顯示密碼圖示的 Google 登入表單。
Google 登入表單中的密碼輸入欄:顯示「顯示密碼」圖示和「忘記密碼」連結。

為行動裝置使用者提供合適的鍵盤

使用 <input type="email"> 為行動版使用者提供適當的鍵盤,並啟用瀏覽器內建的基本電子郵件地址驗證功能,完全不需要 JavaScript!

如果您需要使用電話號碼而非電子郵件地址,<input type="tel"> 會在行動裝置上啟用電話號碼鍵盤。您也可以在必要時使用 inputmode 屬性:inputmode="numeric" 非常適合用於 PIN 碼。如需進一步瞭解 inputmode,請參閱相關說明

防止行動裝置鍵盤遮住「登入」按鈕

但如果不留意,使用行動裝置鍵盤時可能會遮住表單,甚至導致「登入」按鈕遭到遮擋。使用者可能會在瞭解發生的情況前放棄。

Android 手機上登入表單的兩張螢幕截圖:一張顯示手機鍵盤如何遮住「提交」按鈕。
「登入」按鈕:現在顯示,現在不顯示。

盡量避免這種情況,請在登入頁面頂端只顯示電子郵件/電話號碼和密碼輸入欄位,以及「Sign in」按鈕。請在下方放置其他內容。

Android 手機上的登入表單螢幕截圖:登入按鈕不會被手機鍵盤遮住。
鍵盤不會遮住「登入」按鈕。

在各種裝置上測試

您需要針對目標對象測試各種裝置,並據此調整。BrowserStack 可讓您在各種實際裝置和瀏覽器上免費測試開放原始碼專案

iPhone 7、8 和 11 上的登入表單螢幕截圖。在 iPhone 7 和 8 上,手機鍵盤會遮住「登入」按鈕,但在 iPhone 11 上不會
「Sign in」按鈕:在 iPhone 7 和 8 上模糊,但在 iPhone 11 上清晰可見。

考慮使用兩個頁面

有些網站 (包括 Amazon 和 eBay) 會在兩個網頁上要求提供電子郵件地址/電話和密碼,藉此避免發生問題。這種做法也能簡化使用體驗:使用者一次只需執行一項工作。

Amazon 網站上的登入表單螢幕截圖:電子郵件/電話和密碼位於兩個不同的「頁面」上。
兩段式登入:電子郵件或電話號碼,然後輸入密碼。

理想情況下,這項功能應使用單一 <form> 實作。請使用 JavaScript 在最初只顯示電子郵件輸入欄,然後隱藏該欄並顯示密碼輸入欄。如果您必須強制使用者在輸入電子郵件地址和密碼之間前往新頁面,第二頁的表單應包含隱藏的電子郵件值輸入元素,以便密碼管理工具儲存正確的值。如需程式碼範例,請參閱「Chromium 支援的密碼表單樣式」。

協助使用者避免重新輸入資料

您可以協助瀏覽器正確儲存資料及自動填入輸入內容,讓使用者不必記住輸入電子郵件地址和密碼的值。這點在行動裝置上特別重要,對於電子郵件輸入內容而言,便是放棄率較高的關鍵。

這項程序分為兩個部分:

  1. autocompletenameidtype 屬性可協助瀏覽器瞭解輸入內容的角色,以便儲存日後可用於自動填入的資料。如要允許儲存資料來自動填入資料,新型瀏覽器也會要求輸入內容具有穩定的 nameid 值 (不會在每次載入網頁或網站部署時隨機產生),並且位於包含 submit 按鈕的 <form> 中。

  2. autocomplete 屬性可協助瀏覽器使用儲存的資料正確自動填入輸入內容。

針對電子郵件輸入內容,請使用 autocomplete="username",因為 username 會在現代瀏覽器中遭到密碼管理工具辨識,即使您應該使用 type="email",也可能需要使用 id="email"name="email"

針對密碼輸入內容,請使用適當的 autocompleteid 值,協助瀏覽器區分新密碼和目前密碼。

使用 autocomplete="new-password"id="new-password" 建立新密碼

  • 在註冊表單中使用 autocomplete="new-password"id="new-password" 輸入密碼,或在變更密碼表單中輸入新密碼。

使用 autocomplete="current-password"id="current-password" 設定現有密碼

  • 在登入表單中使用 autocomplete="current-password"id="current-password" 輸入密碼,或在變更密碼表單中輸入使用者的舊密碼。這會告訴瀏覽器,您希望瀏覽器使用該網站儲存的目前密碼。

如為報名表單:

<input type="password" autocomplete="new-password" id="new-password" …>

登入:

<input type="password" autocomplete="current-password" id="current-password" …>

支援密碼管理工具

不同瀏覽器處理電子郵件自動填入和密碼建議的方式略有不同,但效果大致相同。在電腦版 Safari 11 以上版本中 (例如,顯示密碼管理工具),然後使用生物特徵辨識驗證 (指紋或臉部辨識) 功能 (如果有的話)。

電腦版 Safari 登入程序的三個階段:密碼管理工具、生物特徵辨識驗證、自動填寫。
使用自動完成功能登入,無須輸入文字!

Chrome 電腦版會顯示電子郵件建議、密碼管理工具,並自動填入密碼。

電腦版 Chrome 登入程序的四個階段:電子郵件完成、電子郵件建議、密碼管理工具、選取項目自動填入。
Chrome 84 中的自動完成登入流程。

瀏覽器密碼和自動填入系統並不簡單。系統用來猜測、儲存及顯示值的演算法並未標準化,且會因平台而異。例如,如同 Hidde de Vries 指出:「Firefox 的密碼管理員利用方案系統補強了自身的經驗法則」。

自動填入:網頁開發人員應知但不瞭解的資訊提供更多關於使用 nameautocomplete 的資訊。HTML 規格列出所有 59 個可能的值。

允許瀏覽器提供高強度密碼建議

現代瀏覽器會使用經驗法則,決定何時顯示密碼管理員 UI 並建議高強度密碼。

以下是 Safari 在電腦上執行這項操作的方式。

電腦上的 Firefox 密碼管理工具螢幕截圖。
Safari 中的密碼建議流程。

(從 Safari 12.0 版開始,系統就會建議使用高強度不重複的密碼)。

內建的瀏覽器密碼產生器是指使用者與開發人員,因此不需要設定「高強度密碼」。瀏覽器可安全地儲存密碼,並視需要自動填入,因此使用者無須記住或輸入密碼。鼓勵使用者善用內建的瀏覽器密碼產生器,也代表他們更有可能在您的網站上使用獨特且強大的密碼,而非重複使用可能在其他地方遭到入侵的密碼。

避免使用者意外缺少輸入內容

在電子郵件和密碼欄位中加入 required 屬性。新式瀏覽器會自動提示並設定缺少資料的焦點。不需要 JavaScript!

電腦版 Firefox 和 Android 版 Google Chrome 的螢幕截圖,顯示缺少資料「請填入這個欄位」提示。
當 Firefox 電腦版 (76 版) 和 Chrome for Android (83 版) 上缺少資料時,出現提示和焦點。

針對手指和拇指設計

幾乎所有與輸入元素和按鈕相關的內容,其預設瀏覽器大小都太小,特別是在行動裝置上。這聽起來似乎很明顯,但許多網站的登入表單都會發生這個常見問題。

確保輸入值和按鈕大小夠大

輸入框和按鈕的預設大小和邊距在電腦上太小,在行動裝置上更是如此。

電腦版 Chrome 和 Android 版 Chrome 中未套用樣式的表單螢幕截圖。

根據 Android 無障礙指南,觸控螢幕物件的建議目標大小為 7 至 10 公釐。Apple 介面指南建議使用 48 x 48 像素,而 W3C 則建議使用至少 44 x 44 CSS 像素。在這方面,針對行動裝置的輸入元素和按鈕,加入約 15 px 的邊框間距;在桌上型電腦上,則增加約 10 px。請使用實際的行動裝置和手指或大拇指試試看。您應該可以輕鬆輕觸每個輸入項目和按鈕。

輕觸目標的大小不正確 Lighthouse 稽核功能可協助您自動偵測輸入元素是否過小。

設計:拇指

搜尋「觸控目標」,您會看到許多食指的圖片。不過,在現實世界中,許多人會使用大拇指與手機互動。大拇指比食指大,因此控制精準度較低。這也是為何我們建議使用適當大小的觸控目標。

放大文字

如同大小和邊框間距,輸入元素和按鈕的預設瀏覽器字型大小都太小,在行動裝置中尤其如此。

電腦版和 Android 版 Chrome 中未套用樣式的表單螢幕截圖。
電腦和行動裝置上的預設樣式設定:輸入的文字太小,導致許多使用者難以理解。

不同平台的瀏覽器會以不同方式調整字型大小,因此很難指定在所有平台上都能正常運作的特定字型大小。我們針對熱門網站進行簡短的問卷調查,其中顯示在電腦上的 13 至 16 像素大小,建議使用這個實際大小,在行動裝置上顯示文字時至少要有 16 個像素。

也就是說,您需要在行動裝置上使用較大的像素大小:在 Chrome 桌面版上,16px 相當易讀,但即使視力良好,在 Android 版 Chrome 上也難以閱讀 16px 文字。您可以使用媒體查詢,為不同的檢視點大小設定不同的字型像素大小。20px 在行動裝置上大致合適,但您應向視力不佳的朋友或同事測試這項功能。

文件使用的字型大小難以辨識 Lighthouse 稽核可協助您自動偵測過小的文字。

輸入內容之間應留有足夠的空間

加入足夠的邊界,確保輸入值與觸控目標有效。換句話說,請將邊界設為大約一根手指寬。

確保輸入內容清晰可見

輸入內容的預設邊框樣式能讓使用者難以察覺輸入內容。在部分平台 (例如 Android 版 Chrome) 上,這些廣告幾乎看不見。

除了邊框間距之外,請新增邊框:在白色背景上,一般來說,使用 #ccc 或更深的顏色會是不錯的選擇。

Android 版 Chrome 中樣式表單的螢幕截圖。
清晰易讀的文字、可見的輸入框邊框、適當的邊框和邊距。

使用內建的瀏覽器功能,在輸入無效值時發出警告

瀏覽器內建的功能可針對具有 type 屬性的輸入內容執行基本表單驗證。如果提交的表單含有無效的值,瀏覽器就會發出警告,並將焦點放在有問題的輸入項目上。

Chrome 電腦版登入表單的螢幕截圖,顯示瀏覽器提示,並將焦點放在無效的電子郵件地址值上。
瀏覽器內建基本驗證功能。

您可以使用 :invalid CSS 選取器,醒目顯示無效資料。請使用 :not(:placeholder-shown),避免選取沒有內容的輸入內容。

input[type=email]:not(:placeholder-shown):invalid {
  color: red;
  outline-color: red;
}

嘗試以不同方式醒目顯示含有無效值的輸入內容。

視需要使用 JavaScript

切換密碼顯示設定

您應新增「顯示密碼」切換按鈕,讓使用者檢查自己輸入的文字。如果使用者無法看到自己輸入的文字,就會影響可用性。目前沒有內建方法可執行此操作,但有實施計畫。您必須改用 JavaScript。

顯示「顯示密碼」切換和「忘記密碼」連結的 Google 登入表單。
Google 登入表單:包含「顯示密碼」切換鈕和「忘記密碼」連結。

以下程式碼使用文字按鈕新增「顯示密碼」功能。

HTML:

<section>
  <label for="password">Password</label>
  <button id="toggle-password" type="button" aria-label="Show password as plain text. Warning: this will display your password on the screen.">Show password</button>
  <input id="password" name="password" type="password" autocomplete="current-password" required>
</section>

以下是讓按鈕看起來像純文字的 CSS:

button#toggle-password {
  background: none;
  border: none;
  cursor: pointer;
  /* Media query isn't shown here. */
  font-size: var(--mobile-font-size);
  font-weight: 300;
  padding: 0;
  /* Display at the top right of the container */
  position: absolute;
  top: 0;
  right: 0;
}

以下是用來顯示密碼的 JavaScript:

const passwordInput = document.getElementById('password');
const togglePasswordButton = document.getElementById('toggle-password');

togglePasswordButton.addEventListener('click', togglePassword);

function togglePassword() {
  if (passwordInput.type === 'password') {
    passwordInput.type = 'text';
    togglePasswordButton.textContent = 'Hide password';
    togglePasswordButton.setAttribute('aria-label',
      'Hide password.');
  } else {
    passwordInput.type = 'password';
    togglePasswordButton.textContent = 'Show password';
    togglePasswordButton.setAttribute('aria-label',
      'Show password as plain text. ' +
      'Warning: this will display your password on the screen.');
  }
}

最終結果如下:

登入表單的螢幕截圖,顯示「顯示密碼」文字按鈕,在 Mac 上的 Safari 和 iPhone 7 上。
在 Mac 和 iPhone 7 的 Safari 中,顯示「顯示密碼」文字「按鈕」的登入表單。

提供可存取的密碼輸入介面

使用 aria-describedby 提供密碼規則說明,方法是提供說明限制的元素 ID。螢幕閱讀器會提供標籤文字、輸入類型 (密碼),然後是說明。

<input type="password" aria-describedby="password-constraints" …>
<div id="password-constraints">Eight or more characters with a mix of letters, numbers and symbols.</div>

新增「顯示密碼」功能時,請務必加入 aria-label,以便警告系統將顯示密碼。否則使用者可能會不小心洩漏密碼。

<button id="toggle-password"
        aria-label="Show password as plain text.
                    Warning: this will display your password on the screen.">
  Show password
</button>

您可以在下列 Glitch 中,查看這兩項 ARIA 功能的實際運作情形:

如要進一步瞭解如何製作無障礙表單,請參閱這篇文章

在提交前即時驗證

HTML 表單元素和屬性內建基本驗證功能,但您也應利用 JavaScript,在使用者輸入資料和嘗試提交表單時執行更全面的驗證。

登入表單程式講義的步驟 5 使用 Constraint Validation API (廣泛支援) 新增自訂驗證機制,使用內建瀏覽器 UI 設定焦點並顯示提示。

進一步瞭解:使用 JavaScript 進行更複雜的即時驗證

數據分析和 RUM

對於註冊和登入表單,「無法評估的項目,無法改善」特別重要。您需要設定目標、評估成效、改善網站,然後不斷重複這一過程。

Discount 可用性測試可協助您試用變更,但您需要實際資料,才能真正瞭解使用者如何體驗註冊和登入表單:

  • 網頁分析:註冊和登入網頁的瀏覽次數、跳出率和離開次數。
  • 互動分析目標程序 (使用者會在何處放棄登入或登入流程?) 和事件 (使用者與表單互動時採取的動作?)
  • 網站成效以使用者為中心的指標 (註冊和登入表單是否因某些原因而速度緩慢,如果是的話,原因為何?)。

您也可以考慮實施 A/B 版本測試,嘗試不同的註冊和登入方法,並分階段推出,以便在對部分使用者進行變更驗證後,再將變更發布給所有使用者。

一般指南

精心設計的 UI 和 UX 可降低登入表單放棄率:

  • 別讓使用者主動搜尋登入!在頁面頂端放置登入表單的連結,並使用簡單易懂的字詞,例如「Sign In」、「Create Account」或「Register」
  • 保持專注!註冊表單並非展示優惠和其他網站功能,以免分散使用者的注意力。
  • 盡量簡化註冊程序。只有在使用者認為提供這些資料有明顯好處時,才收集其他使用者資料 (例如地址或信用卡詳細資料)。
  • 使用者開始填寫註冊表單前,應先清楚說明價值主張。使用者登入後有何好處?提供具體獎勵,協助使用者完成註冊。
  • 盡可能讓使用者透過手機號碼而非電子郵件地址驗證身分,因為有些使用者可能不會使用電子郵件。
  • 讓使用者能輕鬆重設密碼,並將「Forgot your password?」連結設為醒目。
  • 連結至服務條款和隱私權政策文件:一開始就向使用者說明您如何保護他們的資料。
  • 在註冊頁面和登入頁面加入貴公司或機構的標誌和名稱,並確認語言、字型和樣式與網站上的其他部分一致。有些表單似乎不屬於其他內容所屬的網站,尤其是當表單的網址與其他內容的網址截然不同時。

持續學習

相片來源:Meghan SchiereckUnsplash 上提供。