国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

CSS網頁布局:網頁頁面結構化

2024-07-11 08:43:15
字體:
來源:轉載
供稿:網友

  你正在學習CSS布局嗎?是不是還不能完全掌握純CSS布局?通常有兩種情況阻礙你的學習:
  第一種可能是你還沒有理解CSS處理頁面的原理。在你考慮你的頁面整體表現效果前,你應當先考慮內容的語義和結構,然后再針對語義、結構添加CSS。這篇文章將告訴你應該怎樣把HTML結構化。
  另一種原因是你對那些非常熟悉的表現層屬性(例如:cellpadding,、hspace、align="left"等等)束手無策,不知道該轉換成對 應的什么CSS語句。 當你解決了第一種問題,知道了如何結構化你的HTML,我再給出一個列表,詳細列出原來的表現屬性用什么CSS來代替。
  結構化HTML
  我們在剛學習網頁制作時,總是先考慮怎么設計,考慮那些圖片、字體、顏色、以及布局方案。然后我們用Photoshop或者Fireworks畫出來、切割成小圖。最后再通過編輯HTML將所有設計還原表現在頁面上。
  如果你希望你的HTML頁面用CSS布局(是CSS-friendly的),你需要回頭重來,先不考慮“外觀”,要先思考你的頁面內容的語義和結構。
  外觀并不是最重要的。一個結構良好的HTML頁面可以以任何外觀表現出來,CSS Zen Garden是一個典型的例子。CSS Zen Garden幫助我們最終認識到CSS的強大力量。
  HTML不僅僅只在電腦屏幕上閱讀。你用photoshop精心設計的畫面可能不能顯示在PDA、移動電話和屏幕閱讀機上。但是一個結構良好的HTML頁面可以通過CSS的不同定義,顯示在任何地方,任何網絡設備上。
  開始思考
  首先要學習什么是"結構",一些作家也稱之為"語義"。這個術語的意思是你需要分析你的內容塊,以及每塊內容服務的目的,然后再根據這些內容目的建立起相應的HTML結構。
  如果你坐下來仔細分析和規劃你的頁面結構,你可能得到類似這樣的幾塊:
  標志和站點名稱
  主頁面內容
  站點導航(主菜單)
  子菜單
  搜索框
  功能區(例如購物車、收銀臺)
  頁腳(版權和有關法律聲明)
  我們通常采用DIV元素來將這些結構定義出來,類似這樣:
  <div id="header"></div>
  <div id="content"></div>
  <div id="globalnav"></div>
  <div id="subnav"></div>
  <div id="search"></div>
  <div id="shop"></div>
  <div id="footer"></div>
  這不是布局,是結構。這是一個對內容塊的語義說明。當你理解了你的結構,就可以加對應的ID在DIV上。DIV容器中可以包含任何內容塊,也可以嵌套另一個DIV。內容塊可以包含任意的HTML元素---標題、段落、圖片、表格、列表等等。
  根據上面講述的,你已經知道如何結構化HTML,現在你可以進行布局和樣式定義了。每一個內容塊都可以放在頁面上任何地方,再指定這個塊的顏色、字體、邊框、背景以及對齊屬性等等。
  使用選擇器是件美妙的事
  id的名稱是控制某一內容塊的手段,通過給這個內容塊套上DIV并加上唯一的id,你就可以用CSS選擇器來精確定義每一個頁面元素的外觀表現,包括標 題、列表、圖片、鏈接或者段落等等。例如你為#header寫一個CSS規則,就可以完全不同于#content里的圖片規則。
  另外一個例子是:你可以通過不同規則來定義不同內容塊里的鏈接樣式。類似這樣:#globalnav a:link或者 #subnav a:link或者#content a:link。你也可以定義不同內容塊中相同元素的樣式不一樣。例如,通過#content p和#footer p分別定義#content和#footer中p的樣式。從結構上講,你的頁面是由圖片、鏈接、列表、段落等組成的,這些元素本身并不會對顯示在什么網絡設備中(PDA還是手機或者網絡電視)有影響,它們可以被定義為任何的表現外觀。
  一個仔細結構化的HTML頁面非常簡單,每一個元素都被用于結構目的。當你想縮進一個段落,不需要使用blockquote標簽,只要使用p標簽,并對p 加一個CSS的margin規則就可以實現縮進目的。p是結構化標簽,margin是表現屬性,前者屬于HTML,后者屬于CSS。(這就是結構于表現的相分離.)
  良好結構的HTML頁面內幾乎沒有表現屬性的標簽。代碼非常干凈簡潔。例如,原先的代碼<table width="80%" cellpadding="3" border="2" align="left">,現在可以只在HTML中寫<table>,所有控制表現的東西都寫到CSS中去,在結構化的HTML中, table就是表格,而不是其他什么(比如被用來布局和定位)。
上一頁12 下一頁 閱讀全文
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 电白县| 黄冈市| 陕西省| 定兴县| 宁陵县| 阿鲁科尔沁旗| 柯坪县| 利津县| 申扎县| 永定县| 佛坪县| 通道| 山阳县| 繁昌县| 鹤岗市| 东宁县| 鄂托克前旗| 东乌珠穆沁旗| 新郑市| 伊金霍洛旗| 平乐县| 吉林市| 县级市| 宁海县| 潞西市| 承德县| 旺苍县| 陆良县| 那曲县| 武冈市| 蓬溪县| 抚州市| 友谊县| 神农架林区| 丁青县| 车致| 正镶白旗| 罗甸县| 西安市| 微博| 信宜市|