加語義化標簽(開發者可以更加優雅,瀏覽器也可以更好的理解)
搜索引擎檢索,為什么會檢索標題,不會檢索“簡介” ? 這是因為結構的不同。但是結構每個人的class命名習慣都會不一樣,無法做到規范,于是不如出新的標簽。
在有一些低版本的瀏覽器中,h5標簽不兼容,會被認為是div,并不會影響我們的功能。也可以在 script 中新加一行代碼 document.createElement("header") ,但是用了多少標簽,就要寫多少行的 document.createElement("") ,于是有一個第三方的插件 html5shiv.js
使用方法:
<!--[if lt IE 9]><script type="text/javascript" src="http://www.ijquery.cn/js/html5shiv.js"></script><![endif]-->
注意:在頁面中調用Html5.js文件必須添加在頁面的head元素內,因為IE瀏覽器必須在元素解析前知道這個元素,所以這個js文件不能在頁面底部調用。
應用程序標簽
DataList
progress
屬性
鏈接關系描述
鏈接到的地方和當前文檔的關系是什么
<a href="01-sementic-tags.html" rel="pre"></a><a href="02-application-tags.html" rel="next"></a>
rel還出現在其他地方,
<link rel="stylesheet" href="css.css">
link本身不會請求文件,而是rel="stylesheet"才會請求文件
目前國內不流行
結構數據標記
<div itemscope itemtype="www.baidu.com"> <div itemprop="主人">主人</div> <div itemprop="小狗">小狗一</div> <div itemprop="小狗">小狗二</div> </div>
可以方便搜索引擎重點抓取
很高級,但是只有google支持
ARIA
無障礙富互聯網應用程序
<label for="myinput">請輸入您的名字</label> <input type="text" id="myinput">
為什么上面一定要label for呢?
是為了搜索引擎的理解
自定義屬性
也就是 data-* 之類的屬性,他們沒有功能性,只是為了保存dom節點的強相關的數據。
<ul id="list"></ul> <div id="info"></div> <script> var data={ 01:{ name:"張三", age:18 }, 02:{ name:"李四", age:19 }, 03:{ name:"王五", age:20 } }; for (var X in data) { var item=data[X]; var oli=document.createElement("li"); var olist=document.getElementById("list"); oli.appendChild(document.createTextNode(item.name)); olist.appendChild(oli); oli.setAttribute("data-name",item.name); oli.setAttribute("data-age",item.age ); oli.addEventListener("click", function () { var name=this.getAttribute("data-name"); var age=this.getAttribute("data-age"); alert(age+name) }) } </script>
上面的代碼用 setattribue 方法來定義了自定義屬性,然后用getattribute又獲取到了自定義屬性。js也針對自定義屬性出了新的api,也就是 dataset['string'] ,使用這個api可以代替 getAttribute 的方法:
oli.addEventListener("click",function(){ console.log(this.dataset["name"]); })
智能表單
新的表單類型
<input type="date"> <input type="color"> <input type="range">
但是盡量不要在pc端使用,用戶體驗較差,不能自定義樣式。主要適配在移動端。
虛擬鍵盤適配
<input type="text" name="txt_text" id="txt_text"> <input type="number" name="txt_number" id="txt_number"> <input type="email" name="txt_email" id="txt_email"> <input type="tel" name="txt_tel" id="txt_tel"> <input type="url" name="txt_url" id="txt_url">
上面的代碼在pc端上沒有用處,主要是用在移動端可以根據不同的input的 type 來喚出不同的鍵盤。
雖然 input type="email" 看似可以驗證表單,但是真是太弱了,只是驗證有沒有 @ ,真的要驗證的話,還是要自己寫正則表達式
頁面多媒體
音頻
<audio src="A Moment of Reflection.mp3" controls="controls"></audio>
但是默認的播放器太丑了,我們一般是自己寫一個button,然后為這個button添加一個事件:
<script> var btn=document.getElementById("btn"); var btn1=document.getElementById("btn1"); var audio=document.getElementsByTagName("audio")[0]; btn.addEventListener("click", function () { audio.play(); }) btn1.addEventListener("click",function (argument) { audio.pause(); }) </script>
視頻
<video src="A Moment of Reflection.mp4" controls="controls"></video>
但是我們一般不是這樣用的,因為視頻有版權,有些瀏覽器只能支持一兩個,我們一般是source:
<video controls="controls"><source src="下午03-網頁多媒體.web.mp4"><source src="下午03-網頁多媒體.web.ogg"><p>您的瀏覽器不支持</p></video>
還有一個插件,是可以幫我們做兼容的,是https://html5media.info/的組件,ie7以上都可以兼容。
以下是多媒體的屬性;
[image_1b2cut34s130mfufars1a6m6va9.png-66.1kB][1]
字幕
兼容性不是很好,現在還沒有人用
canvas
2d
3d
svg
優勢:體積小,質量高,效果好,可控程度高。
MenuItem 對象
MenuItem 對象是HTML5新增的。
MenuItem 對象表示 HTML <menuitem> 元素。
注意:目前只有Firefox瀏覽器支持 <menuitem> 元素。
訪問 MenuItem 對象
你可以使用 getElementById() 來訪問<menuitem>元素:
var x = document.getElementById("myMenuItem");
創建 MenuItem 對象
你可以使用 document.createElement() 方法創建 <menuitem> 元素:
var x = document.createElement("MENUITEM");
MenuItem 對象屬性
Property | 描述 |
---|---|
checked | 設置或返回菜單項是否應進行檢查 |
command | 設置或返回菜單項 command 屬性的值 |
default | 設置或返回菜單項是否應該是默認的命令 |
disabled | 設置或返回菜單項是否禁用 |
icon | 設置或返回代表菜單項的圖片 |
label | 設置或返回菜單項的 label 屬性值 |
radiogroup | 設置或返回菜單項的 radiogroup 屬性值 |
type | 設置或返回菜單項的 type 屬性值 |
標準屬性和事件
MenuItem 對象同樣支持標準的 屬性 和 事件
如您還有不明白的可以在下面與我留言或是與我探討QQ群308855039,我們一起飛!
TML5 對于初學者甚至是非程序員來說都有著十足的吸引力。實際上,只要你訪問網站,就會和 HTML 打交道。如果能夠熟悉一些關鍵的編程技巧,當你對網站做一些細節調整或優化基本的 Web 元素時就能節省大量的時間(甚至是金錢)。因此,本文精選了 10 個對于 Web 開發者來說非常實用的 HTML 編程技巧,而且它們不需要花太多時間精力就可以輕松掌握。
1. 可與本地緩存媒體資源交互
HTML5 FileSystem API 一開始被認為是 AppCache 的替代方案,用來實現資產的動態緩存。但是你知道嗎,其實你還可以用它來實現與用戶本地設備上存儲文件的交互。
例如,你可以在應用中添加以下功能:
注意:FileSystem API 僅被 Chrome 支持。
如果你想嘗試離線存儲功能,還可以參考以下資源和代碼教程:
2. 進行自動表單驗證
對于網站安全性和流暢的用戶體驗來說,表單驗證非常重要。所以我們應該讓用戶更輕松地在你的網站上輸入各種正確類型的值。
在 HTML5 中有幾種新的輸入類型可用,這些類型已經打包進了預定義的驗證功能:
但當你需要用戶提供某些標準輸入未指定的數據時(例如一個包含特殊字符的用戶名),往往就會出問題了。這就是“pattern”屬性派上用場的時候。
Pattern 可讓你定義自定義規則,然后使用正則表達式(RegEx)驗證表單輸入。RegEx 指定了<input>元素值將要檢查的表達式。
下面是一個添加新規則的示例。例如,你要指定密碼不應超過 15 個字符,并且只能包含小寫字母:
<form action="/action_page.php">
Password: <input?type="password"?name="pw"?pattern="[a-z].{1,15,}">
<input?type="submit">
</form>
為了更好地說明規則,你還可以添加一條自定義消息,告訴用戶為什么他們輸入的密碼不符合要求。只需再加上一行來自定義彈出消息即可:
<form action="/action_page.php">
Password: <input?type="password"?name="pw"?pattern="[a-z].{1,15,}"?title="One to fifteen characters, lowercase only".>>
<input?type="submit">
</form>
3. 為 HTML5 代碼元素創建縮寫
Emmet[4] 是一個很好用的文本編輯器插件,可以簡化你的 HTML/CSS 編碼流程。這個工具使用的語法類似于 CSS 的選擇器,可讓你為標準 HTML 代碼元素創建各種縮寫。
下面是一個例子。如果你輸入:
div#header>h1.logo>a{website}
則會收到:
<div?id="header">
<h1?class="logo"><a?href="">website</a></h1>
</div>
你可以使用 cheat sheet[5] 中的多種已有組合,也可以為任意 HTML 標簽創建自定義組合,然后按 Tab 或 Ctrl + E 將其添加到文本編輯器中。我自己是一名從事了多年開發的web前端老程序員,目前辭職在做自己的web前端私人定制課程,去年我花了一個月整理了一份最適合2019年學習的web前端學習干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關注我的頭條號并在后臺私信我:前端,即可免費獲取。
4. 實現更優的視頻傳輸
使用 video 標簽,可以將支持視頻播放的媒體播放器無縫嵌入到網頁中。
你可以選擇:
此外,你必須為視頻指定“控件”(例如播放、暫停和音量調節),否則用戶將沒有任何控件可用。這里的示例代碼如下:
<video width="768"?height="432"?autoplay>
<source?src="video.mp4"?type="video/mp4">
</video>
為了進一步改善觀看體驗,你還可以嘗試使用以下屬性:
你可以在這個 HTML 速查表 [7] 中找到更多使用方便的多媒體文件標簽。
5. 改善圖像的顯示方式
<picture>標簽有助于優化圖像的顯示方式。
它通常用于:
示例:
<picture>
<source?media="(min-width: 846px)"?srcset="img_1.jpg">
<source?media="(min-width: 300 px)"?srcset="img_2.jpg">
<img?src="img_3.jpg"?alt="logo">
</picture>
<picture>標簽包含兩個附加子元素:
要啟用其他樣式選項,請將以下屬性添加到<source>元素:
<img>元素可用來確保在不支持<picture>元素的瀏覽器中正確顯示圖像。
6. 提升首屏頁面的加載速度
如果你希望你的網站在搜索結果中獲得靠前的排名,并提供出色的用戶體驗,那么就需要重點關注頁面的加載速度。
但是,要在 Google Page Insights 中拿到高分并不是那么容易。雖然這一工具的確會標出你的網站上應該修復的內容,但是對于從頭開始對網站進行編碼的人們并沒有提供明確的優化指導。
谷歌對于首屏設計的官方建議 [8] 有些含糊不清:
所以我們來將其分解為更可操作的幾個步驟:
然后再次運行檢查任務,看看是否還有需要修復的內容。
7. 網站加速
只要將 .zip 文件而不是 index.html 文件發送給瀏覽器,就可以節省大量帶寬和下載時間。
圖片來自 betterexplained[11]
要設置 .gzip 壓縮,你需要在 web 主機 / 服務器上找到 htaccess 文件,并使用以下代碼對其進行修改:
<ifModule mod_gzip.c>
mod_gzip_on Yes
mod_gzip_dechunk Yes
mod_gzip_item_include?file?.(html?|txt|css|js|php|pl)$
mod_gzip_item_include handler ^cgi-script$
mod_gzip_item_include mime ^text/.*
mod_gzip_item_include mime ^application/x-javascript.*
mod_gzip_item_exclude mime ^image/.*
mod_gzip_item_exclude rspheader ^Content-Encoding:.*gzip.*
</ifModule>
如果這樣做不起作用,請參考下面這些針對不同 web 服務器類型的教程:
8. 利用 Microdata 進行 SEO
你可以使用 microdata 將額外的上下文編入網頁。然后,網絡爬蟲就可以從你的頁面中渲染微數據,并為用戶提供更好的瀏覽體驗,以更高的精確性對你的網站建立索引并為其提供更準確的搜索結果排名。
簡而言之,Microdata 由名稱 / 值(name/value)對組成,每一個項目(item)定義一組命名的屬性(property)。
9. 使用 HTML5 本地存儲代替 Cookie
Local Storage(也稱為 DOM 存儲)使你可以在本地存儲用戶數據,這樣就無需通過 HTTP 網絡請求發送數據了。它可以節省帶寬并提升數據存儲能力??雌饋聿诲e吧?
但是有一個重要的警告:本地存儲僅能保存在客戶端,而 cookie 既可以保存在服務器端也可以在客戶端。因此,如果你的網站使用了服務器端的 Cookie 來基于已知的用戶首選項自定義內容,則遷移到本地存儲可能就需要重大的架構更改工作了。
但在比較簡單的情況下(例如你使用 Cookie 來存儲一些基本設置),本地存儲可能是一個很好的替代品,尤其是在網絡連接質量較差的區域。另外請記住,本地存儲對于高敏感數據(例如財務信息)可能不是理想的選擇,并且建議你對本地存儲的所有數據都進行額外的加密。
Jenkov 詳細介紹了如何設置和配置 HTML5 本地存儲 [13]。
10. 編寫有編號項目的降序列表
文章最后介紹一個非常簡單的技巧:你可以使用<reversed>屬性添加降序列表替代升序列表。
下面是一個示例代碼片段:
<ol?reversed>
<li>Ready</li>
<li>Set</li>
<li>Go!</li>
</ol>
聽起來可能沒有多大意義,但是當你想在頁面中添加一些時髦的樣式時,它可能就會派上用場了。
小結
現在你應該掌握了這 10 個新的 HTML5 技巧和竅門,它們應該可以幫助你構建更快、更人性化和更有吸引力的網站。不過千萬要記得,在開始實驗之前先對你的網站進行備份!
原文鏈接:https://mp.weixin.qq.com/s/qtQZUvsnIn0nsFbG51lQQw
作者:前端工匠
*請認真填寫需求信息,我們會在24小時內與您取得聯系。