現在,HTML5和CSS3正躍躍欲試的等待大家,下面讓我們來看看他們是否真的能讓我們的設計提升到下一個高度吧
Web設計師可以使用HTML4和CSS2. 1完成一些很酷的東西。我們可以在不使用陳舊的基於table佈局的基礎上完成文件邏輯結構並創建內容豐富的網站。我們可以在不使用內聯240cb830ca84ebaabbd07850110b414d和0c6dc11e160d3b678d68754cc175188a標籤的基礎上對網站添加漂亮而細膩的風格樣式。事實上,我們目前的設計能力已經讓我們遠離了那個可怕的瀏覽器戰爭時代、專有協議和那些充滿閃爍、滾動和閃爍的醜陋網頁。
雖然我們現在已經普遍使用了HTML4和 CSS2.1,但我們可以做得更好!我們可以重組我們程式碼的結構並能讓我們的頁面程式碼更富有語意化特性。我們可以縮減帶給頁面美麗外觀樣式代碼量並讓他們有更高的可擴展性。現在,HTML5和CSS3正躍躍欲試的等待大家,下面讓我們來看看他們是否真的能讓我們的設計提升到下一個高度吧…
曾經,設計師們經常會跟頻繁使用基於table的沒有任何語意的佈局。不過最終還是要感謝像Jeffrey Zeldman和Eric Meyer這樣的思想革新者,聰明的設計師們慢慢的接受了相對更語義化的e388a4556c0f65e1904146cc1a846bee佈局替代了table佈局,並且開始調用外部樣式表。但不幸的是,複雜的網頁設計需要大量不同的標籤結構代碼,我們把它叫做“e388a4556c0f65e1904146cc1a846bee-soup” 綜合症。也許你很熟悉下面的程式碼: 1e9cef3dee283b0faa4bd5e876889dab
程式碼如下:
<p class="section"> <p class="article"> <p class="header"> <h1>p Soup Demonstration</h1> <p>Posted on July 11th, 2009</p> </p> <p class="content"> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> </p> <p class="footer"> <p>Tags: HMTL, code, demo</p> </p> </p> <p class="aside"> <p class="header"> <h1>Tangential Information</h1> </p> <p class="content"> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> </p> <p class="footer"> <p>Tags: HMTL, code, demo</p> </p> </p> </p> </p>
儘管這有些勉強,但上面這個實例還是可以說明使用HTML4對一個複雜的設計進行程式碼化後依然過於臃腫(其實xHTML1.1也不過如此)。不過值得興奮的是,HTML5解決「e388a4556c0f65e1904146cc1a846bee-soup」 綜合症並帶給我們一套新的結構化元素。這些新的HTML5元素富有更細緻的語義從而代替了那些毫無語義的e388a4556c0f65e1904146cc1a846bee標籤,並同時為CSS的調用提供了」自然」的CSS鉤子。
下面是HTML5的解法實例: 2f8332c8dcfd5c7dec030a070bf652c3
程式碼如下:
<section> <article> <header> <h1>p Soup Demonstration</h1> <p>Posted on July 11th, 2009</p> </header> <section> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> </section> <footer> <p>Tags: HMTL, code, demo</p> </footer> </article> <aside> <header> <h1>Tangential Information</h1> </header> <section> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> <p>Lorem ipsum text blah blah blah.</p> </section> <footer> <p>Tags: HMTL, code, demo</p> </footer> </aside> </section> </section>
如我們所見,HTML5可以讓我們用許多更語意化的結構化代碼標籤代替那些大量的無意義的e388a4556c0f65e1904146cc1a846bee標籤。這種語意化的特性不僅提升了我們網頁的品質和語意,並且大量減少了曾經程式碼中用於CSS必須呼叫的class和id屬性。事實上,CSS3也是可以然透過我們忽略掉所有class和id 的。
跟class屬性說再見,歡迎整齊的標籤
結合了富有新的語義化標記的HTML5,CSS3為web設計師們的網頁提供了神設計師們的網頁提供了神一般的力量。有了HTML5的能量,我們將得到更多的對文件程式碼的控制權,有了CSS3的能量,我們的控制權將趨於無窮大!
即使沒有那些高階的CSS選擇器,我們仍然可以透過強大的HTML5條呼叫不同的容器而不勞駕class和id這類屬性。像以往的p佈局,我們在css中可能要這樣呼叫: p#news {}
程式碼如下:
p.section {} p.article {} p.header {} p.content {} p.footer {} p.aside {}
我們再來看看基於HTML5的實例: section {}
程式碼如下:
article {} header {} footer {} aside {}
這是個進步,但仍有一些問題需要解決。在e388a4556c0f65e1904146cc1a846bee實例中,我們需要透過class或id屬性來呼叫頁面中的元素。這種邏輯將允許我們將樣式應用到文件中的任何一個元素上,無論是整體還是個體。例如在e388a4556c0f65e1904146cc1a846bee實例中,.section 和 .content元素很容易定位。但是在HTML5實例中,實際文件中會有很多個section元素。其實我們可以加入一些特定的屬性選擇器來呼叫那些不同的section元素,但謝天謝地,我沒現在可以用少量的高階CSS選擇器來定位不同的section元素。
不使用class和id定位HTML-5元素
下面讓我們來看看如何在不使用class和id的情況下定位HTML5頁面元素的一個實例,我們可以使用三種CSS選擇器來定位和辨別實例中的元素。如下:
後位選擇器:[CSS 2.1]: EF
子選擇器:[CSS 2.1]: E + F
子元素選擇器:[CSS 2.1]## 子元素選擇器:[CSS 2.1]。
2f8332c8dcfd5c7dec030a070bf652c3了:
##body nav+section {}
#
定位下一个2f8332c8dcfd5c7dec030a070bf652c3元素
作为最外层2f8332c8dcfd5c7dec030a070bf652c3元素下的唯一直属子集元素,这个2f8332c8dcfd5c7dec030a070bf652c3元素也许可以这样定位:
代码如下:
section>section {}
定位23c3de37f2f9ebcb477c4a90aac6fffd元素
可以定位23c3de37f2f9ebcb477c4a90aac6fffd元素的方法有很多,不过最简单的方法当然就是后代选择器了:
代码如下:
section section article {}
定位1aa9e5d373740b65a0cc8f0a02150c53、2f8332c8dcfd5c7dec030a070bf652c3 和c37f8231a37e88427e62669260f0074d元素
这三个元素分别在两个地方都出现过,一是在23c3de37f2f9ebcb477c4a90aac6fffd元素中出现,另一是在15221ee8cba27fc1d7a26c47a001eb9b元素中出现。这种差别能让我们轻松定位每个元素。
代码如下:
article header {} article section {} article footer {}
或者一起定义:
代码如下:
section section header {} section section section {} section section footer {}
到目前为止,我们已经使用CSS2.1选择器排除掉了所有的class和id。那么我们为什么还需要使用CSS3 呢?我很高兴你能这么问…
使用CSS3对HTML5元素进行高级定位
虽然我们已经使用CSS2.1选择器排除掉了所有的class和id,显然还会有很多更复杂的情况需要CSS3的高级选择器来解决。让我们通过完成一下的实例来了解一下如何在不使用无用的class和id属性的情况下利用CSS3定位页面元素。
使用一个唯一的日志 (post)ID定位所有日志
wordpress提供给我们一种包含了ID的每篇日志的源代码输出。这种信息通常用于导航和/或了解资料的意图,不过CSS3可以利用这些唯一的ID来定义这些日志的样式。当然,你还可以像往常那样为每篇日志添加class=”post”这样的属性,但这就与我们练习的意图相冲突了(再加上它没有一点乐趣所在)。使用”子字符串匹配选择器”,我们就可以像下面这样定位所有日志和它们的不同元素了。
代码如下:
article[id*=post-] {} /* 定位所有日志 */ article[id*=post-] header h1 {} /* 定位所有日志中的h1标签 */ article[id*=post-] section p {} /* 定位所有日志中的p标签 */
我们仍然可以使用同样的方式定位评论的元素和它们的子元素。
代码如下:
article[id*=comment-] {} /* 定位所有评论 */ article[id*=comment-] header h1 {} /* 定位所有评论中的h1标签 */ article[id*=comment-] section p {} /* 定位所有评论中的p标签 */
定位一些指定的区域(section)或文章(article)
有很多博客的日志量和评论量都相当大,HTML 5 会将它们由2f8332c8dcfd5c7dec030a070bf652c3或23c3de37f2f9ebcb477c4a90aac6fffd元素组成。为了定位哪些指定的2f8332c8dcfd5c7dec030a070bf652c3 或23c3de37f2f9ebcb477c4a90aac6fffd元素,我们就要转而使用强大的“:nth-child”选择器了:
代码如下:
section:nth-child(1) {} /* 选择第一个 <section> */ article:nth-child(1) {} /* 选择第一个 <article> */ section:nth-child(2) {} /* 选择第二个 <section> */ article:nth-child(2) {} /* 选择第二个 <article> */
同样,我们可以使用“:nth-last-child”选择器定位反序的一些元素。
代码如下:
section:nth-last-child(1) {} /* 选择最后一个 <section> */ article:nth-last-child(1) {} /* 选择最后一个 <article> */ </p> <p>section:nth-last-child(2) {} /* 选择倒数第二个 <section> */ article:nth-last-child(2) {} /* 选择倒数第二个 <article> */
使用更多的方式选择指定元素
另一种选择HTML5中指定元素(如 header、section和footer)的方法就是利用”:only-of-type”选择器的优势。由于这些HTML5元素通常会在很多地方出现不止一次,所以当我们想定位那种在父元素下仅出现过一次的标签时这种方法很方便。例如,我们要选择的是在某元素中有切仅有的唯一一个元素,如以下代码:
代码如下:
<section> <section></section> <section> <section>定位这个section元素</section> </section> <section> <section>定位这个section元素</section> </section> <section> <section>但不定位这个section元素</section> <section>和这个section元素</section> </section> <section></section> </section>
我们可以仅使用以下一行选择器:
代码如下:
section>section:only-of-type {}
再次唠叨,你可以固执的为每个元素添加ID属性,但你会失去代码的可扩展性、维护性和绝对简洁的结构与表现相分离。 CSS3的确能让我们可快速更方便的定位几乎所有没有ID和class属性的页面元素。
总结
【相关推荐】
1. HTML5免费视频教程
5. 关于H5的事件属性详解
以上是H5和CSS3組合使用的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!