HTML是英文Hyper Text Mark-up Language(超文本標記語言)的縮寫,它規(guī)定了HTML的語法規(guī)則,用來表示比“文本”更豐富的意義,比如圖片,表格,鏈接等。瀏覽器(IE,火狐等)軟件知道HTML語言的語法,可以用來查看HTML文檔。目前為止互聯(lián)網(wǎng)上的絕大多數(shù)網(wǎng)頁都是使用HTML語言來編寫的。
簡而言之,HTML的語法就是給文本加上描述標簽(Tag),讓用戶(人或程序)能更好的理解該文本。
下面來看一個最簡單的HTML文檔:
<html>
<head>
<title>第一個Html文檔</title>
</head>
<body>
歡迎訪問<a href="http://m.hgci.cn">W3Cschool官網(wǎng)</a>!
</body>
</html>
在W3Cschool html編程實例中運行上列代碼
效果截圖
所有的HTML文檔都會有一個<html>標簽,<html>標簽可以包含兩個部分:<head>和<body>。
<head> 元素包含了所有的頭部標簽元素。在 <head>元素中你可以插入腳本(scripts), 樣式文件(CSS),及各種meta信息。
可以添加在頭部區(qū)域的元素標簽有: <title>, <style>, <meta>, <link>, <script>, <noscript>, 和<base>.
HTML使用標簽 <a>來設置超文本鏈接。
超鏈接可以是一個字,一個詞,或者一組詞,也可以是一幅圖像,您可以點擊這些內(nèi)容來跳轉(zhuǎn)到新的文檔或者當前文檔中的某個部分。
當您把鼠標指針移動到網(wǎng)頁中的某個鏈接上時,箭頭會變?yōu)橐恢恍∈帧?/p>
在標簽<a> 中使用了href屬性來描述鏈接的地址。
默認情況下,鏈接將以以下形式出現(xiàn)在瀏覽器中:
鏈接的 HTML 代碼很簡單。它類似這樣::
在W3Cschool html編程實例中運行上列代碼
href 屬性描述了鏈接的目標。.
上面的<a href="http://m.hgci.cn">中,href屬性的值就是http://m.hgci.cn。
通過不同的標簽,HTML文檔可以包含不同的內(nèi)容,比如文本,鏈接,圖片,列表,表格,表單,框架等。
前面介紹了HTML文檔的基本格式,下面再做一個詳細說明。
HTML文檔可以用任何文本編輯器(比如記事本,UltraEdit等)創(chuàng)建,編輯,因為它的內(nèi)容在本質(zhì)也只是一些文本。
在HTML文本中,用尖括號括起來的部分稱為標簽。如果想在正文里使用尖括號(或者大與號小與號,總之是同一個東西),必須使用字符轉(zhuǎn)義,也就是說轉(zhuǎn)換字符的原有意義。<應該使用<代替,>則使用>,至于&符號本身,則應該使用&替代(不得不說的是有很多HTML文檔沒有遵循這個規(guī)則,常用的瀏覽器也都能夠分析出&到底是一個轉(zhuǎn)義的開始,還是一個符號,但是這樣做是不推薦的)。
標簽本質(zhì)上是對它所包含的內(nèi)容的說明,可能會有屬性,來給出更多的信息。比如<img>(圖片)標簽有src屬性(用于指明圖片的地址),width和height屬性(用于說明圖片的寬度和高度)。HTML里能使用哪些標簽,這些標簽分別可以擁有哪些屬性,這些都是有規(guī)定的,知道了這里說的基本知識之后,學習HTML其實也就是學習這些標簽了。本文后面會對常用的HTML標簽做出簡短的介紹。
標簽通常有開始部分和結(jié)束部分(也被稱為開始標簽和結(jié)束標簽),它們一起限定了這個標簽所包含的內(nèi)容。屬性只能在開始標簽中指定,屬性值可以用單引號或雙引號括起來。結(jié)束標簽都以/加上標簽名來表示。有時候,有些標簽并不包含其它內(nèi)容(只包括自己的屬性,甚至連屬性都沒有),這種情況下,可以寫成類似這樣:<img src="http://statics.w3cschool.cn/images/w3c/index-logo.png" />。注意最后的一個空格和一個反斜杠,它說明這個標簽已經(jīng)結(jié)束,不需要單獨的結(jié)束標簽了。
某些標簽包含的內(nèi)容中還可以有新的標簽,新的標簽名甚至可能還可以與包含它的標簽的名稱相同(哪些標簽可以包含標簽,可以包含哪些標簽也是有規(guī)定的)。比如:
<div>
<div>分類目錄...</div>
<div>當前分類內(nèi)容列表...</div>
</div>
在這種情況下,最后出現(xiàn)的標簽應該最先結(jié)束。
HTML文檔里所有的空白符(空格,Tab,換行,回車)會被瀏覽器忽略,唯一的例外是空格,對空格的處理方式是所有連續(xù)的空格被當成一個空格,不管有一個,還是兩個,還是100個。之所以有這樣的規(guī)則是因為忽略空白符能讓使用HTML的作者以他覺得最方便的格式來排列內(nèi)容,比如可以在每個標簽開始后增加縮進,標簽結(jié)束后減少縮進。由于英語文本中空格用得很普遍(用于分隔單詞),所以對空格做了這樣的特殊處理。如果要顯示連續(xù)的空格(比如為了縮進),應該用 來代表空格。
最常用的標簽可能是<font>了,它用于改變字體,字號,文字顏色。
加粗,下劃線,斜體字也是常用的文字效果,它們分別用<b>,<u>,<i>表示:
還有一些標簽,用來指出包含的文本有特殊的意義,比如<abbr>(表示縮寫),<em>(表示強調(diào)),<strong>(表示更強地強調(diào)),<cite>(表示引用),<address>(表示地址)等等。這些標簽不是為了定義顯示效果而存在的,所以從瀏覽器里看它們可能沒有任何效果,也可能不同的瀏覽器對這些標簽的顯示效果完全不同。
一篇很長的文章,如果有合適的小標題的話,就可以快速地對它的內(nèi)容進行大致的了解。在HTML里,用來表示標題的標簽有:<h1>,<h2>,<h3>,<h4>,<h5>,<h6>,它們分別表示一級標題,二級標題,三級標題...
<hr>標簽用于在頁面上添加橫線。可以通過指定width和color屬性來控制橫線的長度和顏色。
<img>標簽用于在頁面上添加圖片,src屬性指定圖片的地址,如果無法打開src指定的圖片,瀏覽器通常會在頁面上需要顯示圖片的地方顯示alt屬性定義的文本。
超級鏈接用<a>標簽表示,href屬性指定了鏈接到的地址。<a>標簽可以包含文本,也可以包含圖片。
由于HTML文檔會忽略空白符,所以要想保證正常的分段換行的話,必須指出哪些文字是屬于同一段落的,這就用到了標簽<p>。
也有人不用<p>,而用<br>。<br>只表示換行,不表示段落的開始或結(jié)束,所以通常沒有結(jié)束標簽。
有時,要把文檔看作不同的部分組合起來的,比如一個典型的頁面可能包括三個部分:頁頭,主體,頁腳。<div>標簽專門用于標明不同的部分:
HTML文檔在瀏覽器里通常是從左到右,從上到下地顯示的,到了窗口右邊就自動換行。為了實現(xiàn)分欄的效果,很多人使用表格(<table>)進行頁面排版(雖然HTML里提供表格的本意不是為了排版)。
<table>標簽里通常會包含幾個<tr>標簽,<tr>代表表格里的一行。<tr>標簽又會包含<td>標簽,每個<td>代表一個單元格。
<tr>標簽還可以被<table>里的<thead>或<tbody>或<tfoot>包含。它們分別代表表頭,表正文,表腳。在打印網(wǎng)頁的時候,如果表格很大,一頁打印不完,<thead>和<tfoot>將在每一頁出現(xiàn)。
<th>和<td>非常相似,也用在<tr>里邊,不同的是<th>代表這個單元格是它所在的行或列的標題。
表格用于表示二維數(shù)據(jù)(行,列),一維數(shù)據(jù)則用列表表示。列表可以分為無序列表(<ul>),有序列表(<ol>)和定義列表(<dl>)。前兩種列表更常見一些,都用<li>標簽包含列表項目。
無序列表表示一系列類似的項目,它們之間沒有先后順序。
有序列表中各個項目間的順序是很重要的,瀏覽器通常會自動給它們產(chǎn)生編號。
最后談一下框架,曾經(jīng)非常流行的技術(shù),框架使一個窗口里能同時顯示多個文檔。主框架頁里面沒有<body>標簽,取代它的是<frameset>。
<frameset>標簽的屬性Rows和Cols用于指定框架集(frameset)里有多少行(列),以及每行(列)的高度(寬度)。
<frameset>標簽可以包含<frame>標簽,每個<frame>標簽代表一個文檔(src屬性指定文檔的地址)。
如果覺得這樣的頁面還不夠復雜的話,還可以在<frameset>標簽里包含<frameset>標簽。
這篇文章只是讓從沒有接觸過HTML的人對HTML有個初步的印象,還有很多東西需要學習。本文并沒有列出HTML中所有的標簽,對于列出的標簽也沒有介紹它們的全部屬性。另外,沒有提到的東西里還包括我覺得非常重要的CSS, JavaScript, XHTML, XML, Web Standards,以及它們與HTML的關(guān)系。不過這些也不太可能在一篇文章內(nèi)學會,好在只要入了門,就能利用W3Cschool上很多資源和工具繼續(xù)學習。
學習中如果遇到什么問題可以W3Cschool問答模塊HTML問答中向各位大牛求教哦~
更多建議: