HTML5的一大革新就是語義化標簽的完善
section
w3c規范規定section是用來划分網頁的,表示頁面中的一個內容區塊,比如章節,頁眉,頁腳或頁面的其他部分.可以和h1,h2…等其他標簽結合起來一起使用,表示文檔結構
article
定義可以獨立於內容其余部分的完整獨立內容塊,article元素就是專門為摘要設計的,比如一篇文章
aside
表示article標簽內容之外的,與article標簽內容相關的輔助信 息,aside元素應該被用於無關內容。
- 如果你有你認為應該與主內容分開的內容,那么aside元素是你應該正 確考慮使用的元素。
- 詢問你自己aside元素中的內容是否可以被獨立開來而不會影響文檔或 者section中主內容的含義。
- 可以用在主要內容相關的引用,側邊欄,廣告,nav元素組等
- 簡單來說 :aside的內容如果被刪除,剩下的內容仍然很合理
hgroup
對整個頁面/頁面中的一個內容區塊的標題進行組合
header
一個內容區塊或整個頁面的頭部部分
footer
整個頁面或頁面區塊的尾部
nav
頁面中導航鏈接的部分
figure
- 表示一段獨立的流內容,一般表示文檔主體流內容中的一個獨立單元
- figure元素經常用於圖片
figcaption
- 代表一個圖例的說明
- 代表了figure元素的一個標題或者說是其相關解釋.
- 在使用figcaption時,它最好是figure塊的第一個或者最后一個元素
mark
高亮顯示
progress
進度條
time
<time></time>用來表現時間或日期
<p>我們在每天早上<time>9:00</time>開始營業。</p>參數<p>我在<time datetime=“2016-02-14T20:00Z” pudate>這一天</time>發布了一篇文章。</p>
wbr
<p>一行放不下則在這換行<wbr/>能放下則一行顯示</p>
datalist
選項列表與 input 元素配合使用,可以設置提示信息
<input type="text" id="" list="shopCars"/>
<datalist id="shopCars"> <!--為表單設置可選值-->
<option value="aa"></option>
<option value="ab"></option>
<option value="c"></option>
</datalist>
details
用於描述文檔或文檔某個部分的細節
summary標簽和details一起使用,表示標題,用戶點擊標題時會得到細節信息
<details>
<summary>111</summary>
<ul>
<li>111</li><li>222</li><li>333</li>
</ul>
</details>
output
不同類型的輸出,比如腳本的輸出
<form oninput="x.value= parseInt(a.value)+parseInt(b.value)">
<input type="range" id="a" max="100" min="0" value="50"/>+
<input type="number" id="b" value="50"/>
<output name="x" for="a b">150</output>
</form>
新增標簽的兼容問題
HTML5語義化標簽在IE6-8下,對於不支持的標簽不會有任何的樣式,也默認的當成行內元素來出來,所以在樣式表里要對這些標簽定義一下 它默認的display
通過引入如下js來解決ie9以下新增標簽的兼容問題
<!--[if lt IE 9]> <script type="text/javascript" src="html5.min.js"></script> <![endif]-->
Forms
新增input元素的種類:
- search : 搜索輸入框
- tel : 電話號碼輸入框
- url : 輸入url地址
- email : 郵件輸入框
- number : 數字輸入框
- range :特定范圍內的數值選擇器(通過拖動滾動條改變一定范圍內的數字)
- color : 顏色選取器 只在 Opera 和 Blackberry 瀏覽器
- datetime : 顯示完整日期和時間 UTC標准時間
- datetime-local : 顯示完整日期和時間
- time : 顯示時間
- month : 顯示月
- week : 顯示周
表單新特性
- placeholder
輸入框占位符,常用作輸入提示,在光標聚焦時,占位符自動消失 - autocomplete : 是否保存用戶輸入值
默認為on,關閉提示選擇off - autofocus : 自動聚焦
- required : 此項必填,不能為空
- Pattern : 正則驗證 pattern="\d{1,5}“
- form 屬性 只要加上 form 屬性,表單元素可以放到頁面的任意位置。
- formnovalidate 和 novalidate
它倆都表示不需要驗證表單,直接提交;
novalidate 用於 form 標簽;
formnovalidate 用於 submit類型的提交按鈕。
表單驗證
validity對象,通過下面的valid可以查看驗證是否通過
oText.addEventListener("invalid",fn1,false);
valid : 驗證不通過時返回false
valueMissing : 輸入值為空時
typeMismatch : 控件值與預期類型不匹配
patternMismatch : 輸入值不滿足pattern正則
customError 不符合自定義驗證
setCustomValidity(); 自定義驗證
當表單元素驗證不通過時,會觸發invalid事件,
如何判斷表單元素有沒有驗證通過?
1)所有的表單元素上有個validity對象
2)validity對象上有一些屬性:valid(false) valueMissing(true) patternMismatch(true) typeMismatch(true) customError(true)
注:括號里是驗證不通過時的返回值
setCustomValidity 設置自定義驗證規則
<form action="" >
<!-- <input type="text" name="text" id="text1" pattern="\d{2}"/>-->
<input type="url" name="url" id="text1" />
<input type="submit" value="提交"/>
</form>
<script>
var oText = document.querySelector("#text1");
oText.addEventListener("invalid",function(){
//valid 只要驗證不通過,值為false
console.log(this.validity.valueMissing);/!*配合required屬性,如果為空,則這個值true*!/
},false)
oText.addEventListener("invalid",function(){
console.log(this.validity.customError)
if(this.validity.patternMismatch){
this.setCustomValidity("只能輸入兩位數字");//自定義驗證提示信息
console.log(this.validity.customError)
}else{
this.setCustomValidity('');
}
},false)
oText.addEventListener("invalid",function(){
console.log(this.validity.typeMismatch)
},false)
</script>
全局屬性
- data-yourvalue
自定義屬性
data-name : dataset.name
data-name-first : dataset.nameFirst - Hidden
加上這個屬性,元素則是不可見狀態 - spellcheck
對你輸入的內容糾錯 - tabindex
按下tab鍵可以根據設置的順序進行跳轉 - contenteditable
<p contenteditable="true">請您留言</p>
表示這塊內容是可以編輯的 去掉則不可以修改 - desginMode
<script>
window.document.designMode = “on“
</script>
HTML5表單及其驗證
HTML表單一直都是Web的核心技術之一,有了它我們才能在Web上進行各種各樣的應用。HTML5 Forms新增了許多新控件及其API,方便我們做更復雜的應用,而不用借助其它Javascript框架。
表單仍是以<form>元素作為容器,我們可在其中設置基本的提交特性;
當用戶提交頁面時,表單仍然向服務器發送表單控件的值;
之前老版本中的表單控件,如text radio checkbox等等,都可以按原有方式使用,盡管增加了新的功能;
仍然可以使用javascript操作表單控件。
1.輸入型控件
| Input type | 用途 | 說明 |
|---|---|---|
| 電子郵件地址文本框 | ||
| url | 網頁URL文本框 | |
| number | 數值的輸入域 | 屬性 值 描述 max number 規定允許的最大值 min number 規定允許的最小值 step number 規定合法的數字間隔(如果 step="3",則合法的數是 -3,0,3,6 等) value number 規定默認值 |
| range | 特定值的范圍的數值,以滑動條顯示 | 屬性 值 描述 max number 規定允許的最大值 min number 規定允許的最小值 |
| step number 規定合法的數字間隔(如果 step="3",則合法的數是 -3,0,3,6 等) value number 規定默認值 |
||
| Date pickers | 日期,時間選擇器 | 僅Opera9+支持,包含date, month, week, time, datetime, datetime-local |
| search | 用於搜索引擎,比如在站點頂部顯示的搜索框 | 與普通文本框用法一樣,只不過這樣更語文化 |
| color | 顏色選擇器 | 僅Opera支持 |
將原本type為text的input控件聲明為以上特殊類型,是為了給用戶呈現不同的輸入界面(移動平台上支持這些不同的輸入界面,這里就不細說),而且表單提交時會對其值做進一步的驗證。下面展示這些新表單元素,請用支持這些表單元素的瀏覽器查看,IE對其支持最差。
E-mail:
date:
range: number: color:
2. 表單新特性和函數
2.1 placeholder
當用戶還沒有輸入值時,輸入型控件可能通過placeholder向用戶顯示描述性說明文字或者提示信息,這在目前網站中很常見,一些JS框架都會提供類似功能,簡單的說下在舊版本中常用的解決方案,為輸入控件創建一個label,然后通過CSS控制些label的位置使之覆蓋在輸入控件上面,當label獲得焦點時,瀏覽器會把焦點指向輸入控件。不過有了placeholder,新的瀏覽器就內置了這一功能,其特性值會以淺灰色樣式顯示在輸入框中,當輸入框獲得焦點並有值后,該提示信息自動消失。
如:
<p><label for="runnername">Runner:</label>
<input id="runnername"name="runnername" type="text" placeholder="First and last name" />
</p>
2.2 autocomplete
其實在IE6中,autocomplete就已經實現,不過現在這一特性終於標准化了,瀏覽器通過autocomplete特性能夠知曉是否應該保存輸入值以備將來使用,autocomplete應該用一保護用戶敏感數據,避免本地瀏覽器對它們進行不安全的存儲。
| 類型 | 作用 |
|---|---|
| on | 該字段無需保護,值可以被保存和恢復 |
| off | 該字段需要保護,值不可以保存 |
| unspecified | 包含<form>的默認設置,如果沒有被包含在表單中或沒有指定值,則行為表現為on |
如:
<form action="" method="get" autocomplete="on">
Name:<input type="text" name="name" /><br />
E-mail: <input type="email" name="email" autocomplete="off" /><br />
<input type="submit" />
</form>
當用戶提交過一次表單后,再次訪問,name的輸入框會提示你曾輸入的值,而email則不會提示。
2.3 autofocus
頁面載入時,我們通過autofocus指定某個表單元素獲得焦點,但每個頁面只允許出現一個autofocus,如果設置多個則相當於未指定些行為。目前Opera10,Chrome和Safari瀏覽器支持。如果用戶有希望焦點轉移的情況下,使用autofocus會惹惱用戶。
2.4 list特性和datalist
通過使用list,開發人員能夠為某個輸入型控件構造一個選值列表,其使用方法:
Webpage: <input type="url" list="url_list" name="link" />
<datalist id="url_list">
<option label="W3School" value="http://www.w3school.com.cn" />
<option label="Google" value="http://www.google.com" />
<option label="Microsoft" value="http://www.microsoft.com" />
</datalist>
Webpage:
2.5 required
required 屬性規定必須在提交之前填寫輸入域(不能為空)。它是表單驗證最簡單的一種方式方法,使用方法:
Name: <input type="text" name="usr_name" required="required" />
2.6 pattern
pattern 屬性規定用於驗證 input 域的模式(pattern),模式(pattern) 是正則表達式。那些type為email或url的輸入控件內置相關正則表達式,如果value不符合其正則表達式,那表單將通不過驗證,無法提交。使用方法:
Country code: <input type="text" name="country_code"
pattern="[A-z]{3}" title="Three letter country code" />
2.7 novalidate
novalidate 屬性規定在提交表單時不應該驗證 form 或 input 域。
如:
<form action="demo_form.asp" method="get" novalidate="true">
E-mail: <input type="email" name="user_email" />
<input type="submit" />
</form>
3. 表單驗證
表單驗證是一套系統,它為終端用戶檢測無效的數據並標記這些錯誤,是一種用戶體驗的優化,讓web應用更快的拋出錯誤,但它仍不能取代服務器端的驗證,重要數據還要要依賴於服務器端的驗證,因為前端驗證是可以繞過的。
目前任何表單元素都有八種可能的驗證約束條件:
| 名稱 | 用途 | 用法 |
|---|---|---|
| valueMissing | 確保控件中的值已填寫 | 將required屬性設為true,<input type="text"required="required"/> |
| typeMismatch | 確保控件值與預期類型相匹配 | <input type="email"/> |
| patternMismatch | 根據pattern的正則表達式判斷輸入是否為合法格式 | <input type="text" pattern="[0-9]{12}"/> |
| toolong | 避免輸入過多字符 | 設置maxLength,<textarea id="notes" name="notes" maxLength="100"></textarea> |
| rangeUnderflow | 限制數值控件的最小值 | 設置min,<input type="number" min="0" value="20"/> |
| rangeOverflow | 限制數值控件的最大值 | 設置max,<input type="number" max="100" value="20"/> |
| stepMismatch | 確保輸入值符合min,max,step的設置 | 設置max min step,<input type="number" min="0" max="100" step="10" value="20"/> |
| customError | 處理應用代碼明確設置能計算產生錯誤 | 例如驗證兩次輸入的密碼是否一致 |
下面展現瀏覽器自帶的驗證功能請在Chrome、Opera或Firefox中查看:
源代碼:
<form name="register1" id="register1">
<p><label for="runnername">RunnerName:</label>
<input id="runnername"name="runnername" type="text" placeholder="First and last name" required="required" autofocus="autofocus"/>
</p>
<p><label for="phone">Tel #:</label>
<input id="phone" name="phone" type="text" pattern="\d{3}-\d{4}-\d{4}"
placeholder="xxx-xxxx-xxxx"/></p>
<p><label for="emailaddress">E-mail:</label>
<input id="emailaddress" name="emailaddress" type="email"
placeholder="For confirmation only"/></p>
<p><label for="dob">DOB:</label>
<input id="dob" name="dob" type="date"
placeholder="MM/DD/YYYY"/></p>
<p>Count:<input type="number" id="count" name="count" min="0" max="100" step="10"/></p>
<p><label for="style">Shirt style:</label>
<input id="style" name="style" type="text" list="stylelist" title="Years of participation"
autocomplete="off"/></p>
<datalist id="stylelist">
<option value="White" label="1st Year"/>
<option value="Gray" label="2nd - 4th Year"/>
<option value="Navy" label="Veteran (5+ Years)"/>
</datalist>
<fieldset>
<legend>Expectations:</legend>
<p>
<label for="confidence">Confidence:</label>
<input id="confidence" name="level" type="range"
onchange="setConfidence(this.value)"
min="0" max="100" step="5" value="0"/>
<span id="confidenceDisplay">0%</span></p>
<p><label for="notes">Notes:</label>
<textarea id="notes" name="notes" maxLength="100"></textarea></p>
</fieldset>
<p><input type="submit" name="register" value="Submit" onclick=" checkForm()"/></p>
</form>
可是各個瀏覽器驗證行為不一致,我們可能需要統一其驗證行為,借助javascript我們可以統一瀏覽器的驗證行為。
還是以上上述HTML為基礎,我們為其加上相關javascript:
//自定義表單控件驗證行為
var checkvalue = function(e){
var el = e.target;
var isvalid = el.checkValidity();
if(isvalid){
el.className= "";
el.parentElement.getElementsByTagName("label")[0].className="";
}else{
el.className= "error";
el.parentElement.getElementsByTagName("label")[0].className="error";
}
e.stopPropagation();
e.preventDefault();
}
//定義表單驗證方法
function invalidHandler(evt) {
checkvalue(evt);
}
function loadDemo() {
var myform = document.getElementById("register1");
//注冊表單的oninvlid事件
myform.addEventListener("invalid", invalidHandler, true);
for(var i=0;i< myform.elements.length-1;i++){
//注冊表單元素的onchange事件,優化用戶體驗
myform.elements[i].addEventListener("change",checkvalue,false);
}
}
//在頁面初始化事件(onload)時注冊的自定義事件
window.addEventListener("load", loadDemo, false);
最后說下輸入兩次密碼匹配的驗證,寫的很簡單:
<form name="passwordChange">
<p><label for="password1">New Password:</label>
<input type="password" id="password1" onchange="checkPasswords()"></p>
<p><label for="password2">Confirm Password:</label>
<input type="password" id="password2" onchange="checkPasswords()"></p>
</form>
<button onclick="document.passwordChange.password1.checkValidity()">Check Validity</button>
function checkPasswords() {
var pass1 = document.getElementById("password1");
var pass2 = document.getElementById("password2");
if (pass1.value != pass2.value)
pass1.setCustomValidity("兩次輸入的密碼不匹配");
else
pass1.setCustomValidity("");
}
