篇介紹了表單的使用,表單有很多控件,比如輸入框,密碼框、文本域,按鈕等。按類型可分如下:
此類控件有很多種類型,使用<input type="類型">語法,常見類型如下:
type 值 | 含義 |
text | 文字字段 |
password | 密碼域,用戶看不到明文,以*代替 |
radio | 單選按鈕 |
checkbox | 多選按鈕 |
button | 普通按鈕 |
submit | 提交按鈕 |
reset | 重置按鈕 |
image | 圖像域,用圖像作為背景的提交按鈕 |
hidden | 隱藏域,不可見的輸入框 |
file | 文本域,用于上傳文件等非文本數據 |
文本輸入框和密碼框
除了顯示形式不一樣,其它屬性一樣,有以下屬性:
如下是文本輸入框和密碼框制作一個登錄表單
html代碼:
<!DOCTYPE html>
<html>
<body>
<h1>用戶登錄</h1>
<form action="/demo/html/action_page.php">
<label for="fname">用戶名:</label><br>
<input type="text" id="username" name="username" value=""><br>
<label for="lname">密碼:</label><br>
<input type="password" id="pwsd" name="pwsd" value=""><br><br>
<input type="submit" value="提交">
</form>
</body>
</html>
顯示效果:
HTML5 輸入類型
除了以上幾種類型,HTML5 還增加了多個新的輸入類型:
如下代碼:
<!DOCTYPE html>
<html>
<body>
<form action="/demo/demo_form.asp">
數字類型(1 到 5 之間):
<input type="number" name="quantity" min="1" max="5">
IE9 及早期版本不支持 type="number"。<br>
color 選擇顏色:
<input type="color" name="color"><br>
生日:
<input type="date" name="bday"><br>
年月:
<input type="month" name="bdaymonth"><br>
年周:
<input type="week" name="week_year"><br>
時間:
<input type="time" name="usr_time"><br>
一定范圍
<input type="range" name="points" min="0" max="10"><br>
E-mail:
<input type="email" name="email">
能夠在被提交時自動對電子郵件地址進行驗證<br>
搜索:
<input type="search" name="googlesearch"><br>
電話:
<input type="tel" name="usrtel">
目前只有 Safari 8 支持 tel 類型。<br>
url:
<input type="url" name="url">
提交時能夠自動驗證 url 字段<br>
<input type="submit">
</form>
</body>
</html>
效果如下:
單選和多選按鈕
使用 type = “radio” 和 type =“checkbox” 定義是單選還是多選,除了name和value屬性外,單選和多選都有一個 checked屬性定義默認選擇的項,checked = “true”指選中那個選項,表單會將 checked = “true” 的選型值傳遞給后臺。
如下實例:
<!DOCTYPE html>
<html>
<body>
<h4>單選和多選</h4>
<form action="/demo/demo_form.asp">
水果:
<input type="radio" name="shuiguo" value="banner" checked> 香蕉
<input type="radio" name="shuiguo" value="apple"> 蘋果
<br><br>
省份:
<input type="checkbox" name="shengfen" value="shannxi" checked> 陜西
<input type="checkbox" name="shengfen" value="sanxi"> 山西
<input type="checkbox" name="shengfen" value="gdong"> 廣東
<br><br>
<input type="submit">
</form>
</body>
</html>
顯示效果:
單選和多選傳遞給后臺的數據是不一樣的,如下會看到地址欄中的數據,多選會發送多個值,后臺將會獲取一個數組形式的數據。
/demo/demo_form.asp?shuiguo=banner&shengfen=shannxi&shengfen=sanxi
普通按鈕、提交按鈕、重置按鈕
普通按鈕:type = “button”,一般配合腳本使用,語法如下:
<input type="button" name="名稱" value="按鈕值" onclick="腳本程序" />
value 值就是按鈕在頁面顯示的文字,onclick屬性定義了腳本事件,這里指單擊按鈕時所進行的處理。
如下示例:
<!DOCTYPE html>
<html>
<body>
<form>
<input type="button" value="普通按鈕">
<input type="button" value="打開窗口" onclick="window.open()">
<input type="button" value="您好" onclick="alert('您好')">
</form>
</body>
</html>
單擊您好按鈕
提交按鈕:type = “submit”,用于提交表單內容,是一種特殊按鈕。
如剛才的登錄表單,提交后會返回結果:
重置按鈕:type="reset",用于清除表單數據,也是一種特殊按鈕。
輸入數據
點擊重置按鈕后,表單數據清空
重置清空數據
HTML5 按鈕
除了使用input定義按鈕,還可以使用 html5 新增的<button> 標簽定義按鈕,button 使用語法如下:
<form action="/demo/html/action_page.php">
<button type="button">普通按鈕</button>
<button type="submit">提交按鈕</button>
</form>
其它輸入類控件
隱藏域 —— hidden
文件域 —— file
如下示例:
<form action="/demo/html/action_page.php">
<label for="fname">隱藏域:</label>
<input type="hidden" id="hidden" name="hidden" value=""><br>
<label for="lname">文件域:</label>
<input type="file" id="file" name="file" value=""><br>
<input type="submit" value="提交">
</form>
顯示效果
可以看到,隱藏域在頁面中不顯示,單擊文件域選擇文件按鈕可以選擇文件,比如word文件,電子表格文件等,會以非文本方式傳送到后臺的,常用來實現文件上傳功能。
除了input 類型的控件,還有文本域 textarea ,一種特殊的文本框,它與input 文本輸入框的區別就是可以輸入多行文字,input 文本輸入框是單行的無法輸入多行文字。
如下示例:
<p>textarea 元素定義多行輸入字段。</p>
<form action="/demo/html/action_page.php">
<textarea name="message" rows="10" cols="30">The cat was playing in the garden.</textarea>
<br><br>
<input type="submit">
</form>
效果如下:
rows 屬性定義文本域的高度是幾行,cols 定義文本域寬度占幾列,比如上面定義了高10行寬30列的文本域。
下拉菜單作用和單選按鈕類似,只不過它更加節省空間,當要選擇的選型很多時,就不適合使用radio空間,所以當選項很多的時候,使用下拉菜單,語法如下:
<select name="名稱">
<option value="選項值1" selected>選項1</option>
<option value="選項值2">選項3</option>
更多option......
</select>
多選列表和多選按鈕類似,一樣為了節省空間,當數據選項比較多時,使用多選列表,語法如下:
<select name="名稱" size="可看見的列表項數" multiple>
<option value="選項值1" selected>選項1</option>
<option value="選項值2">選項3</option>
更多option......
</select>
多選比下拉菜單不同之處是多了一個multiple屬性,定義多選的,且表現形式也不一樣,不是下拉而是一個列表。
如下代碼:
<!DOCTYPE html>
<html>
<body>
<form action="/demo/demo_form.asp">
下拉菜單:<br>
<select name="cars">
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
<option value="fiat">Fiat</option>
<option value="audi">Audi</option>
</select>
<br>
多選列表:<br>
<select name="cars" size="3" multiple>
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
<option value="fiat">Fiat</option>
<option value="audi">Audi</option>
</select>
<br><br>
<input type="submit">
</form>
</body>
</html>
顯示效果:
這里需要注意的是,多選列表多選時需要按住ctrl鍵同時鼠標單擊選擇才能多選,效果如下:
到這里,已介紹了大部分的表單控件,現在你可以使用他們制作自己的表單,表單通常在動態網站中使用,這為以后制作動態網站打下基礎。
還有許多屬性沒有講到,比如html5新增的一些屬性和功能,可自行參考 w3cshool 等網站學習,感謝關注,學習愉快!
上篇 : 前端入門——html 表單
下篇: 前端入門 —— 網頁中使用窗口框架
輯導語:在工作中我們時常會遇到一些關于表單優化的問題,雖然表單聽起來是比較簡單而常見的設計要素,但要想設計出簡潔直觀,清晰明了的表單還需要考慮更多的細節因素。本文總結了如何設計出簡單且包容的表單的一些技巧,希望對你有所啟發。
最近我的工作涉及一項艱巨的任務——如何為我的產品設計出體驗更好的表單。當我接到這個任務時,我根本不知道好的表單和壞的表單有什么區別。我需要思考:我應該設計一個多步驟的表單還是一個單頁的表單?我應該使用占位符嗎?如何使我的表單更符合包容性設計的原則呢?
幾乎每一個在網頁端發生的重要交互,從注冊登陸、購買產品服務到發起客戶幫助或者獲得反饋,都需要通過表單來完成。因此,雖然表單可能不是設計中最激動人心的設計元素,但學會如何設計一個好的表單是一項非常有價值的技能。
在學習了一些資料之后,我把我認為最好的最有效的表單設計進行了羅列。然而,我們需要記住的是:表單是一個高度依賴上下文的設計元素,所以在實際操作中是有例外的,設計師需要具體情況具體分析。在我們開始之前,讓我們快速的來回顧一下表單的五個主要元素:
多列表單容易讓人產生誤解:用戶非常容易忽略一些必填的內容,把信息填入錯誤的文本框或者完全放棄填寫表單。下面的圖片展示了用戶面對多列表單時視線是如何移動的。
當一個表單沒有提供清晰的填寫路徑時,用戶需要很長時間去理解它,更別說去完成它了。當一個表單的填寫路徑是線性的,比如說單列表單,用戶在完成時就不會存在誤解。
確保只讓用戶輸入我們真正需要的內容。但是記住,你讓用戶輸入的信息越多,用戶就越不想填寫這個表單,因此,這會影響轉化率等因素并導致銷售損失。設計師需要明確讓用戶填寫這一條信息的目的是什么。在這里,我們可以使用一個叫做“問題協議”的系統方法,來確定表單的內容。
好的表單就是在正確的時間向用戶詢問正確的信息,否則它可能會讓用戶失去興趣?;貞浺幌挛覀冏约壕€上購物的場景:如果網站需要你在購買東西之前就填寫付款信息,你會怎么想?或者必須在填寫名字之前填寫地址?因此,我們要嘗試從用戶的視角來思考如何建立表單的排列邏輯。
創建有邏輯的表單項分組幫助用戶更清晰的理解信息,這是因為用戶只能同時關注在一個群組上,而不是被無數雜亂的信息打亂。被分在一個組的信息代表著它們彼此之間是有關聯的,因此,如何在視覺上區分開不同的群組也是很重要的,比如在群組之間添加空白區域。
首先,標簽應該盡量使用頂部對齊,根據眼動測試研究,把標簽放在輸入框的上面而不是旁邊,會幫助用戶更快地理解信息。
從包容性設計的角度來看,標簽也非常重要。視力正常的用戶可以閱讀它們,視障用戶可以在屏幕閱讀器的幫助下聽到它們,運動障礙用戶可以在更大的點擊區域內使用它們。
因為占位符在 HTML 的規范中并不意味著是用戶一定要去閱讀的內容。占位符之所以被運用在表單中是因為它在用戶輸入信息的時候提供了額外的指導。但是問題在于這些文本是灰色的,低對比度的顏色使用戶很難去閱讀。在包容性設計的研究中發現,占位符經常被瀏覽器的自動翻譯功能或者一些屏幕閱讀器忽略掉,并不會翻譯或者閱讀它們。
所以我們為什么要使用占位符呢?使用占位符的原因是因為它們在視覺上節省了大量空間。但問題在于,當用戶點擊時,占位符會自動消失,所以用戶無法二次檢查他們是否在正確的輸入框中輸入了正確的內容。
一個通用的解決方法是使用懸浮的標簽,把標簽作為占位符使用。當用戶開始在一個表單項進行輸入的時候,標簽會懸浮在輸入框的上方,這種方式受到歡迎的原因是可以節省空間,總體而言,這是一種非常優雅、自然的模式。
然而,懸浮標簽的缺點多于優點。首先,缺少空間來設置提示文字,因為標簽和占位符是相同的。第二,標簽比較小,以及它較低的對比度讓用戶很難區分是占位符文字還是真實的數值,最后,在空間的節省上也不會特別多,因為標簽需要空間進行移動。
所以我們該如何做呢?我們可以把提示文字放在輸入框的上方,就像下圖中這樣。因此,屏幕閱讀器就不會跳過這些文字,同時它也提供了一個較大的點擊區域。
按照慣例,我們習慣用一個紅色的星號來代表必填表單項,但是如果你了解我在上文中提到的“問題協議”工具,那么大部分的表單項都是必須要填寫的。因此,幫用戶標注出可選的輸入框會更加方便有意義。當我們想讓一些元素脫穎而出時,我們會利用視覺設計來凸顯這個元素是不同的。
對于設計師來說,我們可以快速理解紅色星號的含義,但是總有人會對此表示疑惑。在標簽中加入“可選”的文字,會比用視覺符號更加清晰明確。
在包容性設計中有關于如何用紅色星號作為必填字段的建議:可以在表單中添加標記,以便讓屏幕閱讀器在閱讀時,說出“這是一個必填表單項”的語,進而幫助用戶理解。
當用戶提交的內容出現錯誤,并且需要告知用戶時,在界面上需要有三個方面的呈現。
在 html 網頁中,出現在瀏覽器標題欄的標題是用來定義網頁的名稱的,標題是當屏幕瀏覽器開始閱讀時第一個需要閱讀的部分,因此,在這里展現“用戶提交的信息有誤”能最有效最快捷得反饋給用戶。
這個解決方法需要用 javascript 來計算表單當中的錯誤并且體現出來,所以說這可能并不屬于一個設計師的職能范圍,你只需要確保將此功能告知開發人員。
這種類型的錯誤反饋是更加清晰明確的。在表單上面顯示錯誤的總結,因此用戶就知道他具體需要修改哪部分的內容。
一個好的錯誤總結不僅僅有錯誤信息還包含了錯誤位置的鏈接。錯誤位置的鏈接讓用戶快速跳轉到表格中填寫錯誤的部分,而不是讓用戶先記住哪里發生了錯誤,再從頭閱讀一遍表單,從大量信息中取尋找他們的錯誤之處。
當然,當沒有錯誤出現時,錯誤總結模塊就需要被隱藏了。
在一個理想的情況下,所有的錯誤提醒都是實時的,這意味著當用戶填寫完一個表單項(或不填寫)的時候,就會在表單項附近出現一個錯誤提示文本,這可以有效的減少用戶滑上滑下去尋找錯誤提示信息的時間。
最近也有一種趨勢,是將錯誤提示信息放在文本框的上方,這是因為一些自動填充功能也許會遮擋這些提示,手機上的鍵盤也會遮擋住這些關鍵信息,用戶很容易忽視掉。
對于稍微復雜一點的表單輸入,比如說輸入一個新的密碼。好的解決方案是用實時的提示來展示密碼的強弱程度,也就是說,在用戶正在輸入的時候,就可以實時展示出目前密碼的強弱程度。這將最有效地讓用戶知道他們是否滿足了這個表單的填寫要求。
CTA 行動按鈕應該使用描述性的語言而不是模糊的語言。動詞會幫助用戶理解接下來會發生什么。雖然行動按鈕上的描述應該是簡短的,但是也不能因此犧牲語言的清晰性。一定要使用讓每個人都理解的語言。
主要按鈕和次要按鈕之間做明顯的視覺區分,主要是為了避免用戶按下錯誤的按鈕,視覺上的區別可以引向最預期的操作。
一般情況下,提交按鈕最應該被放置在表單的底部,因為大多數用戶都會從上往下填寫表單然后提交表單。另外一個需要思考的點是按鈕對齊的位置是向左對齊,向右對齊還是居中對齊。我覺得更好的方案是向左對齊,因為表單中的標簽也是向左對齊的,所以當用戶將視線向下移動時,他們也會自然的看向這個位置。
在需要使用返回按鈕的表單中,比如多步驟表單,提交按鈕仍然應該向左對齊,然而返回按鈕應該被放置在表單的頂部,這樣可以幫助用戶區分主要按鈕(即提交按鈕)和次要按鈕(即返回按鈕),有助于用戶誤點擊返回按鈕。
當表單中所填的內容可以被分類時,使用多步驟表單可以提升表單的可用性。讓一個較長的表單被分成幾個較短的表單可以幫助用戶更清晰得填寫表單。當表單中要填寫的信息較多時,最好使用多步驟表單。同時,也可以向用戶展示填寫的進度,這是提高用戶參與度的好方法。
進度指示器將表單內容分成多個有邏輯,有順序的步驟來向用戶展示當前的進度。這給用戶傳達了清晰的反饋,讓用戶知道他們已經完成了多少內容,以及多少內容還沒有完成。
然而,除非你很確定整個表單一共有幾個步驟,并且毫無偏差,不然不要用數字去標識,反而會引發更多得疑惑。
最后,設計師需要證明每一個表單元素存在的必要性。表單對于用戶來說是乏味的,但是設計師的任務是讓表單變得盡可能的可用和易用。像其他設計一樣,表單也可以通過測試來不斷優化,所以說盡早測試,頻繁測試,讓測試的結果推動下一次的設計提升。
歡迎大家自由評論,點贊或者分享。
作者:Omar Andani;譯者:王英睿;審校:李澤慧、張聿彤;編輯:孫淑雅
原文鏈接:https://uxdesign.cc/8-ways-to-make-forms-more-user-friendly-50f3f22c708c
本文由@TCC翻譯情報局 翻譯發布于人人都是產品經理,未經許可,禁止轉載。
題圖來自 Unsplash,基于CC0協議。
tml表單元素-html教程
表單元素文本類:
123456
表單元素-按鈕類:
復選框與單選框:
你的愛好是:
吃飯
睡覺
打豆豆
你的性別是:
男
女
文件選擇:
下拉列表與下拉框:div+css,html學習,html入門
iframeset:
iframe:
[成笑笑博客]SEO中DIV+CSS命名規則-seo教程
[成笑笑博客]HTML標簽概述-html教程
CSS樣式表知識總結-css教程
html5和html4之間的區別-html5教程
*請認真填寫需求信息,我們會在24小時內與您取得聯系。