ホームページ >ウェブフロントエンド >htmlチュートリアル >HTML5+CSS3アプリの詳しい説明
この記事では主に HTML5+CSS3 アプリケーションの詳細な説明を紹介しますので、必要な方はぜひ参考にしてください。実際に私たちのデザインを次のレベルに引き上げられるかどうか見てみましょう
Web デザイナーは HTML4 と CSS2.1 を使用して素晴らしいことを実現できます。古い表ベースのレイアウトを使用せずに、ドキュメントの論理構造を完成させ、コンテンツが豊富な Web サイトを作成できます。インラインの 240cb830ca84ebaabbd07850110b414d タグや 0c6dc11e160d3b678d68754cc175188a を使用せずに、美しく繊細なスタイルを Web サイトに追加できます。実際、私たちの現在のデザイン能力は、ブラウザー戦争、独自のプロトコル、ちらつき、スクロール、フラッシュだらけの醜い Web ページの恐ろしい時代から私たちを遠くに連れて行ってくれました。
現在、HTML4 と CSS2.1 が一般的に使用されていますが、さらに改善できる可能性があります。コードを再構築し、ページ コードをよりセマンティックにすることができます。ページに美しい外観を与え、よりスケーラブルにするスタイリング コードの量を減らすことができます。さて、HTML5 と CSS3 が本当に私たちのデザインを次のレベルに引き上げることができるかどうかを見てみましょう...
以前は、デザイナーはテーブルベースのセマンティック レイアウトの頻繁な使用とは無関係であることがよくありました。しかし最終的には、Jeffrey Zeldman や Eric Meyer のような革新者のおかげで、賢明なデザイナーはテーブル レイアウトの代わりに比較的セマンティックな
レイアウトを徐々に受け入れ、外部スタイル シートを呼び出すようになりました。しかし、残念ながら、複雑な Web デザインにはさまざまなタグ構造コードが必要であり、これを「e388a4556c0f65e1904146cc1a846bee-soup」症候群と呼んでいます。おそらく、次のコードに精通しているかもしれません: 1e9cef3dee283b0faa4bd5e876889dab
コードをコピーしますコードは次のとおりです:
<div class="section"> <div class="article"> <div class="header"> <h1>Div Soup Demonstration</h1> <p>Posted on July 11th, 2009</p> </div> <div 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> </div> <div class="footer"> <p>Tags: HMTL, code, demo</p> </div> </div> <div class="aside"> <div class="header"> <h1>Tangential Information</h1> </div> <div 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> </div> <div class="footer"> <p>Tags: HMTL, code, demo</p> </div> </div> </div> </div>
これは少し気が進まないですが、上記の例は次のことを行うことができます。複雑なデザインは、コード化された後でもまだ肥大化しすぎています (実際、xHTML1.1 はそれ以上のものではありません)。しかし、興味深いのは、HTML5 が「e388a4556c0f65e1904146cc1a846bee-スープ」症候群を解決し、一連の新しい構造要素を提供してくれることです。これらの新しい 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 では、より多くのセマンティック構造を置き換えることができます。 code タグ 意味のない e388a4556c0f65e1904146cc1a846bee タグが大量にあります。このセマンティクス機能は、Web ページの品質とセマンティクスを向上させるだけでなく、コード内で CSS のために呼び出す必要がある class 属性と id 属性を大幅に削減します。実際、CSS3 ではすべてのクラスと ID を無視することもできます。
クラス属性に別れを告げ、きちんとしたタグを歓迎しましょう新しいセマンティックタグが豊富な HTML5 と組み合わせることで、CSS3 は Web デザイナーに Web ページに神のような力を提供します。 HTML5 の力により、ドキュメント コードをより詳細に制御できるようになり、CSS3 の力で制御できるようになります。
高度な CSS セレクターがなくても、class や id などの属性を気にせずに、強力な HTML5 句を通じてさまざまなコンテナーを呼び出すことができます。前の p レイアウトと同様に、CSS で次のように呼び出すことができます: p#news {}
コードをコピーします コードは次のとおりです:
div.section {} div.article {} div.header {} div.content {} div.footer {} div.aside {}
HTML5 に基づいた例を見てみましょう: セクション {}
コードをコピーします コードは次のとおりです:
article {} header {} footer {} aside {}
これは進歩ですが、解決する必要がある問題がまだいくつかあります。 e388a4556c0f65e1904146cc1a846bee の例では、class または id 属性を通じてページ内の要素を呼び出す必要があります。このロジックにより、全体または個別に、ドキュメント内の任意の要素にスタイルを適用できるようになります。たとえば、e388a4556c0f65e1904146cc1a846bee の例では、.section 要素と .content 要素を簡単に見つけることができます。ただし、HTML5 の例では、実際のドキュメントには多くのセクション要素が含まれます。実際には、特定の属性セレクターを追加して、これらのさまざまなセクション要素を呼び出すこともできますが、ありがたいことに、現在、さまざまなセクション要素をターゲットにするための高度な CSS セレクターがいくつかありません。
クラスと ID を使用せずに HTML-5 要素を検索する
クラスと ID を使用せずに HTML5 ページ要素のインスタンスを検索する方法を見てみましょう。インスタンス内の要素を検索して識別するために 3 つの CSS セレクターを使用できます。以下の通り:
后代选择器:[CSS 2.1]: EF
兄弟选择器:[CSS 2.1]: E + F
子元素选择器:[CSS 2.1]: E > F
下面让我们来看看如何不使用class和id而完成对文档中的那些section元素的定位吧:
定位最外层的2f8332c8dcfd5c7dec030a070bf652c3元素
考虑到我们的例子并不是一套完整的HTML5代码,所以我们假定在6c04bd5ca3fcae76e30b72ad730ca86d元素下有个c787b9a589a3ece771e842a6176cf8e9元素与2f8332c8dcfd5c7dec030a070bf652c3元素是兄弟元素。这样的话,我们就可以向下面代码那样定位最外层的
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属性的页面元素。
总结
我相信随着时间的推进和更多浏览器的支持,HTML5和CSS3将越来越受欢迎,它们将为web设计师们带来更无穷的能量,让我们的web前端更上一个台阶。
相关推荐:
以上がHTML5+CSS3アプリの詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。