摘要:年月日作為推薦標準發(fā)布年月日作為提案被提出年月作為推薦標準發(fā)布年月日作為推薦標準發(fā)布年月日作為推薦標準發(fā)布。規(guī)定元素的上下文菜單。上下文菜單在用戶點擊元素時顯示。規(guī)定元素仍未或不再相關。規(guī)定是否對元素進行拼寫和語法檢查。規(guī)定元素的行內(nèi)樣式。
作者:陳大魚頭
github: KRISACHAN
上一篇分享了CSS的邏輯屬性與盒子模型中分享了一些有關設備屏幕的知識以及瀏覽器視口的坐標構成。本篇則會分享HTML相關的一些知識。
我們在序章的開頭就簡單的講解了HTML的誕生歷史,本篇不作詳細講解,有興趣的可以去看wikipedia。
HTML大事記首先我們簡單地來看一下HTML的發(fā)展歷程(具體各個版本的區(qū)別亦不做講解)。
1982年Tim Berners-Lee創(chuàng)建了html;
1989年Tim Berners-Lee規(guī)定HTML并在1990年底寫出瀏覽器和服務器軟件;
1991年底Tim Berners-Lee提及HTML標簽(它描述18個元素,包括HTML初始的、相對簡單的設計);
1993年互聯(lián)網(wǎng)工程任務組(IETF)發(fā)布首個HTML規(guī)范的提案;
1994年IETF創(chuàng)建一個HTML工作組;
1995年11月24日HTML 2.0作為IETF RFC 1866發(fā)布;
IETF于1996年9月12日關閉它的HTML工作組;
1997年1月14日HTML 3.2作為W3C推薦標準發(fā)布。這是首個完全由W3C開發(fā)并標準化的版本;
1997年12月18日HTML 4.0作為W3C推薦標準發(fā)布;
1998年4月24日進行微調(diào),不增加版本號;
1999年12月24日HTML 4.01作為W3C推薦標準發(fā)布;
2000年5月ISO/IEC 15445:2000("ISO HTML",基于HTML 4.01嚴格版)作為ISO/IEC國際標準發(fā)布。
2014年10月28日HTML 5作為W3C推薦標準發(fā)布;
2015年3月20日HTML6作為提案被W3C提出;
2016年11月HTML5.1作為W3C推薦標準發(fā)布;
2017年12月14日HTML5.2作為W3C推薦標準發(fā)布;
2018年10月18日HTML5.3作為W3C推薦標準發(fā)布。
魚頭注:上面某些信息看得真讓人發(fā)愁。。。。。。
HTML標簽對于應付日常的業(yè)務,寫在同一行的就用span,需要換行的就用div,如果有超鏈接就用a。長得丑?加color啊,不夠大?用font-size: xx-large啊。嗯,沒有任何問題,精通HTML。: )
此刻正在看這篇文章的你估計會覺得:“HTML有什么好說的,每天都寫,鍵盤上div那幾個字母都要被我按爛了,這只有初學者才需要學?!?/p>
嗯,說得對。那本篇結束,再見!
咦,不對,其實在魚頭看來HTML并不簡單,作為一門原本是為了學者們的交流而誕生的語言,本身就是充滿嚴謹性的,加上又已經(jīng)發(fā)展了37個年頭,更是不簡單。
魚頭注:本篇不會對HTML的標簽結構跟文件組成進行介紹,有需要了解的童鞋可以參考MDN跟W3school
首先我們來看一個基本的HTML頁面會有什么東西:
hello world hello world
從上面我們可以知道一個基本的HTML頁面會有定義文檔類型的,告知瀏覽器這是一個HTML文檔的,定義各種文檔屬性的,以及定義內(nèi)容主體的。
首先我們一起來看看這幾大標簽的具體情況以及子標簽詳情。
DOCTYPE是個聲明而不是標簽,它必須在HTML 文檔的第一行,位于 標簽之前。它是指示 web 瀏覽器關于頁面使用哪個 HTML 版本進行編寫的指令。必須始終向 HTML 文檔添加 聲明,這樣瀏覽器才能獲知文檔類型。詳情請參考HTML 元素和有效的 DTD。
html限定了文檔的開始點和結束點,在它們之間是文檔的頭部和主體。我們來看看在標簽中可添加的專屬屬性有哪些:
屬性 | 值 | 描述 |
---|---|---|
manifest | url | 定義一個 URL,在這個 URL 上描述了文檔的緩存信息。(已廢棄) |
xmlns | http://www.w3.org/1999/xhtml | 定義 XML namespace 屬性。 |
HTML 屬性賦予元素意義和語境。下面的全局屬性可用于任何 HTML 元素。
屬性 | 描述 |
---|---|
accesskey | 規(guī)定激活元素的快捷鍵。 |
class | 規(guī)定元素的一個或多個類名(引用樣式表中的類)。 |
contenteditable | 規(guī)定元素內(nèi)容是否可編輯。 |
contextmenu | 規(guī)定元素的上下文菜單。上下文菜單在用戶點擊元素時顯示。 |
data-* | 用于存儲頁面或應用程序的私有定制數(shù)據(jù)。 |
dir | 規(guī)定元素中內(nèi)容的文本方向。 |
draggable | 規(guī)定元素是否可拖動。 |
dropzone | 規(guī)定在拖動被拖動數(shù)據(jù)時是否進行復制、移動或鏈接。 |
hidden | 規(guī)定元素仍未或不再相關。 |
id | 規(guī)定元素的唯一 id。 |
lang | 規(guī)定元素內(nèi)容的語言。 |
spellcheck | 規(guī)定是否對元素進行拼寫和語法檢查。 |
style | 規(guī)定元素的行內(nèi) CSS 樣式。 |
tabindex | 規(guī)定元素的 tab 鍵次序。 |
title | 規(guī)定有關元素的額外信息。 |
translate | 規(guī)定是否應該翻譯元素內(nèi)容。 |
標簽用于定義文檔的頭部,它是所有頭部元素的容器。描述了文檔的各種屬性和信息,包括文檔的標題、在 Web 中的位置以及和其他文檔的關系等。
那么有哪些標簽是可以放在內(nèi)的呢?
首先是
通常情況下,瀏覽器會從當前文檔的 URL 中提取相應的元素來填寫相對 URL 中的空白。
使用
根據(jù)上面的DEMO
/head-base.html)我們可以發(fā)現(xiàn),在設置了
其次是scheme,此屬性是用來設置或返回用于解釋 content 屬性的值的格式。例子如下:
有趣的是,MDN上有這么一段描述:
Notes: Do not use this attribute as it is obsolete. There is no replacement for it as there was no real usage for it. Omit it altogether.
意思就是不要用這屬性,因為這屬性并沒什么用處。: )
然后是name,此屬性定義文檔級元數(shù)據(jù)的名稱。值得注意的是,如果定義的元數(shù)據(jù)設置了itemprop, http-equiv or charset ,就不能再設置name了。
name的值含義如下
值 | 描述 |
---|---|
application-name | 定義正運行在該網(wǎng)頁上的網(wǎng)絡應用名稱 |
author | 文檔作者 |
description | 其中包含頁面內(nèi)容的簡短和精確的描述。一些瀏覽器,如Firefox和Opera,將其用作書簽頁面的默認描述。 |
generator | 包含生成頁面的軟件的標識符。 |
keywords | 包含與逗號分隔的頁面內(nèi)容相關的單詞。 |
referrer | 控制所有從該文檔發(fā)出的 HTTP 請求中HTTP Referer 首部的內(nèi)容。 |
others | 其他的內(nèi)容。 |
詳細name值,可以訪問https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/meta#屬性。
最后我們來看看http-equiv,此屬性把content屬性連接到HTTP頭部。
值 | 描述 |
---|---|
content-security-policy | 允許站點管理者在指定的頁面控制用戶代理的資源。除了少數(shù)例外,這條政策將極大地指定服務源 以及腳本端點。這將幫助防止跨站腳本攻擊。 |
default-style | 這個屬性指定了在頁面上使用的首選樣式表. content屬性必須包含 元素的標題, href屬性鏈接到CSS樣式表或包含CSS樣式表的元素的標題。 |
refresh | 這個屬性指定如果 |
詳細http-equiv值,可以訪問https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/meta#屬性。
body標簽內(nèi)存放文檔的內(nèi)容。內(nèi)可使用的標簽大概有357個,其中MDN給內(nèi)的元素分了11類。有需要了解的可參考https://developer.mozilla.orgzh-CN/docs/Web/HTML/Element。
按照MDN的劃分,一共有以下11類標簽:
1. 內(nèi)容分區(qū):
內(nèi)容分區(qū)元素允許你將文檔內(nèi)容從邏輯上進行組織劃分。
2. 文本內(nèi)容
使用 HTML 文本內(nèi)容元素來組織在開標簽 `](https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/body) 和閉標簽 ` 里的塊或章節(jié)的內(nèi)容。這些元素能標識內(nèi)容的宗旨或結構,而這對于 [accessibility 和 SEO 很重要。
3. 內(nèi)聯(lián)文本語義
使用 HTML 內(nèi)聯(lián)文本語義(Inline text semantics)定義一個單詞、一行內(nèi)容,或任意文字的語義、結構或樣式。
4. 圖片和多媒體
HTML 支持各種多媒體資源,例如圖像,音頻和視頻。
5. 內(nèi)嵌內(nèi)容
除了常規(guī)的多媒體內(nèi)容,HTML 可以包括各種其他的內(nèi)容,即使它并不容易交互。
6. 腳本
為了創(chuàng)建動態(tài)內(nèi)容和 Web 應用程序,HTML 支持使用腳本語言,最突出的就是 JavaScript。某些元素支持此功能。
7. 編輯標識
這些元素能標示出某個文本被更改過的部分。
8. 表格內(nèi)容
這里的元素用于創(chuàng)建和處理表格數(shù)據(jù)。
9. 表單
HTML 提供了許多可一起使用的元素,這些元素能用來創(chuàng)建一個用戶可以填寫并提交到網(wǎng)站或應用程序的表單。
10. 交互元素
HTML 提供了一系列有助于創(chuàng)建交互式用戶界面對象的元素。
11. Web組件
Web 組件是一種與 HTML 相關聯(lián)(HTML-related)的技術,簡單來說,它允許創(chuàng)建自定義元素,并如同普通的 HTML 一樣使用它們。此外,你甚至可以創(chuàng)建經(jīng)過自定義的標準 HTML 元素。標簽語義化
語義化到底重不重要?
有的人認為,在可以“競價排名”以及“軟件界面”的場景多于“富文本”的前提下,HTML語意并不重要。只要div、span、a標簽差不多就能走天下了,最有意思的是,百度百科跟維基百科這類文檔類網(wǎng)站,HTML結構大多數(shù)都是上述的情況。
但是,標簽語義化真的不重要嗎?
這個問題魚頭暫時不回答,但會在后續(xù)的文章中體現(xiàn)并實踐魚頭的想法。如果你對這個問題感興趣,也可以通過留言或者加魚頭好友或者進魚頭的微信群來討論,聯(lián)系方式在文章底部。
我們知道,在HTML中,每個標題是通過標題標簽來定義的,標題標簽一共有6個,分別是:h1~6。例子如下:
我是一級標題
我是二級標題
我是三級標題
我是四級標題
我是五級標題
我是六級標題
如果是連續(xù)的標題,則可以用 來連接:
我是一級標題
我是二級標題
我是三級標題
我是四級標題
我是五級標題
我是六級標題
如果是段落內(nèi)容,則用 :
我是段落內(nèi)容
如果我們要列一個列表則可以用 或 。如果只是要標記項目,我們可以用 ,例子如下:
若是標記順序,則用 ,例子如下:
- 向前走300米
- 右轉
- 向前走300米
- 右轉
- 向前走300米
當然我們也可以按需嵌套。
- 先用蛋白一個、鹽半茶匙及淀粉兩大匙攪拌均勻,調(diào)成“腌料”,雞胸肉切成約一厘米見方的碎丁并用“腌料”攪拌均勻,腌漬半小時。
- 用醬油一大匙、淀粉水一大匙、糖半茶匙、鹽四分之一茶匙、白醋一茶匙、蒜末半茶匙調(diào)拌均勻,調(diào)成“綜合調(diào)味料”。
- 雞丁腌好以后,色拉油下鍋燒熱,先將雞丁倒入鍋內(nèi),用大火快炸半分鐘,炸到變色之后,撈出來瀝干油汁備用。
- 在鍋里留下約兩大匙油,燒熱后將切好的干辣椒下鍋,用小火炒香后,再放入花椒粒和蔥段一起爆香。隨后雞丁重新下鍋,用大火快炒片刻后,再倒入“綜合調(diào)味料”繼續(xù)快炒。
- 如果你采用正宗川菜做法,最后只需加入花生米,炒拌幾下就可以起鍋了。
- 如果你在北方,可加入黃瓜丁、胡蘿卜丁和花生米,翻炒后起鍋。
在我們平常說話的時候,為了突出重點,我們往往會強調(diào)某些詞,就如如下的例子:
我非常喜歡加班
如果是重音強調(diào),則:
魚頭,明天別遲到了
在我們身邊任何的地方都是非常需要語義學的,我們依靠過去的學習經(jīng)驗,通過所見的物體就可以知道它代表的意義。例如“紅燈停,綠燈行”。如果這個語義出錯或者弄反了,造成的影響是不堪設想的。
同樣的道理,我們需要確保使用了正確的元素來給予內(nèi)容正確的意思、作用以及外形。
每個標簽都有自己的使用場景,如果要全部列出來,也不是一篇文章能寫得完的。更多的需要能堅持看到這里的你來探索,當然也非常歡迎你來跟魚頭一起討論標簽語義化的問題。
參考資料:HTML
HTML(超文本標記語言)
HTML元素參考
HTML元素
HTML 文字處理基礎
HTML 元素和有效的 DTD
HTML全局屬性
HTML 標簽
HTML DOM Meta 對象
MDN 標簽
重學前端
HTML4
HTML5
HTML5.1
10個HTML 5.1的新功能
HTML5.2
HTML5.3
html6test
HTML6提案
ARIA in HTML
文檔對象模型
如果存在呢?HTML6-廣義概念
【Hello CSS】系列【Hello CSS】是以CSS基礎概念為主題的系列文章,旨在幫助大家更深刻地了解并且提高CSS在各位開發(fā)者心目中的地位。由于魚頭我水平有限,文筆有限,如果各位在文章中發(fā)現(xiàn)有任何不合理,不正確的地方,還煩不吝指出,我會非常感謝的;如果通過文章有任何想法或疑問,也希望各位能積極留言,我們互相探討;如果通過本系列文章有所收獲,這就讓魚頭我喜不自勝了!
如果你也喜歡 CSS,喜歡探討技術,或者對本文,本系列有任何的意見或建議,你可以掃描下方二維碼,關注微信公眾號“ 魚頭的Web海洋 ”,隨時與魚頭互動。歡迎!衷心希望可以遇見你。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/115008.html
摘要:年月日作為推薦標準發(fā)布年月日作為提案被提出年月作為推薦標準發(fā)布年月日作為推薦標準發(fā)布年月日作為推薦標準發(fā)布。規(guī)定元素的上下文菜單。上下文菜單在用戶點擊元素時顯示。規(guī)定元素仍未或不再相關。規(guī)定是否對元素進行拼寫和語法檢查。規(guī)定元素的行內(nèi)樣式。 作者:陳大魚頭 github: KRISACHAN 上一篇分享了CSS的邏輯屬性與盒子模型中分享了一些有關設備屏幕的知識以及瀏覽器視口的坐標...
摘要:內(nèi)聯(lián)樣式標簽魚頭注根據(jù)張鑫旭老師在有趣個選擇器可以干掉個選擇器分享過個級聯(lián)選擇器可以擊敗個選擇器目前已無此現(xiàn)象。 作者:陳大魚頭 github: KRISACHAN 在上一篇的HTML的標簽與語意中簡單的介紹了HTML標簽跟其一些屬性,向各位堅持看到這里的親表示真誠的感謝。本篇主要會分享一些跟CSS選擇器(CSS Selectors)相關的內(nèi)容,有興趣的請繼續(xù)往下看。 CSS選擇...
摘要:不存在或格式不正確會導致文檔以兼容模式呈現(xiàn)標準模式的排版和運作模式都是以該瀏覽器支持的最高標準運行。又稱內(nèi)核及以上版本,等內(nèi)核及以上。內(nèi)核原為,現(xiàn)為內(nèi)核等。如果不能確定時,首選使用自然樣式標簽 HTML 語義化 HTML標簽的語義化是指:通過使用包含語義的標簽(如h1-h6)恰當?shù)乇硎疚臋n結構 css命名的語義化是指:為html標簽添加有意義的class 為什么需要語義化: 去...
摘要:不存在或格式不正確會導致文檔以兼容模式呈現(xiàn)標準模式的排版和運作模式都是以該瀏覽器支持的最高標準運行。又稱內(nèi)核及以上版本,等內(nèi)核及以上。內(nèi)核原為,現(xiàn)為內(nèi)核等。如果不能確定時,首選使用自然樣式標簽 HTML 語義化 HTML標簽的語義化是指:通過使用包含語義的標簽(如h1-h6)恰當?shù)乇硎疚臋n結構 css命名的語義化是指:為html標簽添加有意義的class 為什么需要語義化: 去...
閱讀 3503·2023-04-26 02:44
閱讀 1634·2021-11-25 09:43
閱讀 1528·2021-11-08 13:27
閱讀 1892·2021-09-09 09:33
閱讀 907·2019-08-30 15:53
閱讀 1772·2019-08-30 15:53
閱讀 2781·2019-08-30 15:53
閱讀 3115·2019-08-30 15:44