Heim >Web-Frontend >CSS-Tutorial >Der beste Weg, ein title_CSS/HTML zu definieren

Der beste Weg, ein title_CSS/HTML zu definieren

WBOY
WBOYOriginal
2016-05-16 12:10:542172Durchsuche

作者:阿宏 2005-4-15 20:45:18
原文:What is the Best Way to Mark up the Title of a Document?
说明:本文是 《Web Standards Solutions: The Markup and Style Handbook》一书中的一章。书号:ISBN:1590593812。我们会陆续翻译此书中有价值的章节。
原作者:Dan Cederholm
翻译:阿宏
一个文档标题,最好的定义方法是什么?要回答这个问题,先设想我们要在一个页面上定义文章的标题,通常我们有三个方法来实现这个简单目的:

方法一: 有意义吗?
文章标题
虽然在某些情况下会是一个方便的标签,但它并不能表达出标题的完整含义。采用这个方法的一个好处是,我们可以对它附加一个CSS规则,分配其一个heading class,使其文字象标题一样显示。

.heading {
font-size: 24px;
font-weight: bold;
color: blue;
}
ok,现在所有的标题都用heading class标记成了大号的粗体字体,并且为蓝色。太棒了!但是这样做对吗?如果有人用一个不支持CSS的浏览器来观看,会怎样呢?

举个例子,如果我们设置的这个外部样式表的规则不被老版本的浏览器支持,会怎样?又或者有视觉障碍的人用屏幕阅读器来阅读这个页面,又会怎样?一个访问者通过这些途径所看到(或听到)的应该和这个页面上正常的文本没有任何区别。

尽管class="heading"为这个标签增加了一点意义,但仍然只是一个普通的标签,可以被大多数浏览器的缺省样式所修改掉。

搜索引擎检索这个页面时会略过标签,就好象它不存在一样,不会对其可能包含的关键字给于一点额外的重视。在后面我们会更多的谈到搜索引擎和标题的关系。

最后,由于标签是一个内嵌元素,我们可能需要把它嵌套在一个额外的块级元素中,比如

标签或

标签,为的是使它能够形成单独的行,这会进一步被非必要的代码弄乱你的标签。而这些额外增加的标签却是必须的,这样才能使不支持CSS的浏览器显示出没有差别的文本。

方法二:

组合

文章标题


使用一个段落标签,将会给我们带来块级的显示,会把文本变成粗体。但是用这个方法标记一个重要的标题时,我们面对的是同样无意义的结果。

不象方法A,标签能在可视化的浏览器中把文字显示成粗体——甚至在不支持CSS的浏览器中。但是和标签一样,搜索引擎也不会因为有一些东西在段落中被加粗了而给予更高的优先。

难以设计样式

用普通的

的组合,也带来了另一个缺憾——无法把这个标题设计成不同于其他段落的样式。我们可能想用一个特别的样式来突出标题,来使页面内容更清晰更具结构,但是用这个方法只能使其显示成粗体。

方法三:样式加实质

文章标题


恩,多么好的标题定义。大多数的网页设计者对它都很熟悉。其实适当的使用它们, 就能为页面内容提供灵活的、可索引的、以及可样式化的结构。

这也是聪明的定义方法,你会发现它很简单。不再需要额外的标签,你可以说,这仅仅比另外两个方法节省了一点点的字节,可以忽略不计,但节省一点是一点。

一直到

,代表了标题的六个级别,从最重要的(

)到最次要的(

)。他们本身就是块级的,不需要增加其它元素来使其单独成行。简单,有效——就是好工具。

轻松定制样式

因为我们使用

标签是唯一的,而

标签更适合使用在整个页面,所以我们可以用各种各样的CSS方法来样式化。

更重要的是,尽管完全不用样式,一个标题标签也能明显的表示出一个标题!可视化的浏览器把

显示成更大的粗体。一个非样式化的页面将以被期望的那样显示文档结构,用适当的标题标签来传达意思。

Screenreader, PDAs, Mobiltelefone sowie visuelle und nicht-visuelle Browser verstehen alle, was zu tun ist, wenn sie auf ein Title-Tag stoßen, behandeln es richtig und behandeln es ernster als gewöhnlichen Text auf der Seite. Mit dem -Tag wird es von Browsern, die CSS nicht unterstützen, nicht besonders behandelt.

Ärgerliche Standardstile

In der Vergangenheit haben Designer aufgrund der hässlichen Browser-Standardeinstellungen möglicherweise vollständig auf die Verwendung von Title-Tags verzichtet. Vermeiden Sie alternativ die Verwendung von

aufgrund der großen Größe der Standardwerte und verwenden Sie stattdessen einen höheren numerischen Titel-Tag, um eine kleinere Größe zu erreichen.

Es ist jedoch wichtig zu betonen, dass wir diese Titel-Tags problemlos mithilfe von CSS ändern können – ein

muss beispielsweise kein riesiger Standard sein, der mehr als die Hälfte des Bildschirms einnimmt. Später werde ich zeigen, wie einfach es ist, Titel-Tags mit CSS zu formatieren, und Ihnen hoffentlich dabei helfen, einige Ihrer überwältigenden Ängste zu zerstreuen.

Suchmaschinenfreundlich

Das ist ein großer Vorteil. Suchmaschinen lieben Title-Tags. Andererseits bedeutet ein -Tag oder ein einfaches fettes Absatz-Tag etwas weniger. Die entsprechende Kennzeichnung Ihrer Titel von

erfordert nur wenig Aufwand Ihrerseits, erleichtert aber das Crawlen Ihrer Seiten, sodass die Leute sie letztendlich finden können.

Suchmaschinen-Bots legen besonderen Wert auf Titel-Tags – hier können Sie einige Schlüsselwörter einfügen. Genau wie werden sie entlang des Title-Tags durchsucht. Wenn Sie diese Tags nicht verwenden, werden die darin enthaltenen Schlüsselwörter nicht als wertvoll erachtet und ignoriert. </p> <p>Mit ein wenig Aufwand können Sie also die Wahrscheinlichkeit erhöhen, dass Menschen Ihre Website aufgrund des Inhalts Ihrer Seite finden. Hört sich gut an, nicht wahr? </p> <p>Über die Reihenfolge der Überschriften<br>Im Beispiel ist diese bestimmte Überschrift die wichtigste auf der Seite, da es sich um den Titel des Dokuments handelt. Daher verwenden wir das wichtigste Titel-Tag, <h1>. In Anlehnung an die W3C-Spezifikation halten einige Leute das Überspringen mehrerer Überschriftenebenen für eine schlechte Praxis. Stellen Sie sich zum Beispiel vor, wir befinden uns auf der folgenden Seite: </p> <p><h1>Artikeltitel</h1> <br>Unser nächster Titel (sofern er nicht mit einem anderen <h1> wiederholt wird) sollte <h2> sein, dann <h3> usw. Sie sollten nach <h1> wahrscheinlich nicht ein Level überspringen und direkt zu <h3> übergehen. Ich stimme dem oben genannten Standpunkt eher zu und behalte die Kontinuität der Ebenen entlang des Textes bei, um eine Layoutstruktur aufzubauen. Auf diese Weise ist es einfacher, Titel und Stile zu einer bereits vorhandenen Seite hinzuzufügen, und Sie reduzieren Fehler, die durch die Verwendung zusätzlicher Nummern entstehen. </p> <p>Wie bereits erwähnt, verwenden Designer möglicherweise <h4>, um den wichtigsten Titel auf einer Seite zu kennzeichnen, einfach weil die Standardschriftgröße nicht so unangenehm groß ist wie <h1>. Aber denken Sie daran: Zuerst Struktur, dann Design. Wir können CSS jederzeit verwenden, um Überschriften in jeder gewünschten Textgröße zu formatieren. <br></p></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>Stellungnahme:</span><div>Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn</div></div></div><div class="nphpSytBox"><span>Vorheriger Artikel:<a class="dBlack" title="CSS löst das Problem der vertikalen Zentrierung unbekannter Höhe_CSS/HTML" href="https://m.php.cn/de/faq/1247.html">CSS löst das Problem der vertikalen Zentrierung unbekannter Höhe_CSS/HTML</a></span><span>Nächster Artikel:<a class="dBlack" title="CSS löst das Problem der vertikalen Zentrierung unbekannter Höhe_CSS/HTML" href="https://m.php.cn/de/faq/1250.html">CSS löst das Problem der vertikalen Zentrierung unbekannter Höhe_CSS/HTML</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>In Verbindung stehende Artikel</h2><em><a href="https://m.php.cn/de/article.html" class="bBlack"><i>Mehr sehen</i><b></b></a></em><div class="clear"></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-6t+ed+2i-1n-4w" data-ad-client="ca-pub-5902227090019525" data-ad-slot="8966999616"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/de/faq/841.html" title="Zusammenfassung dessen, worauf Sie beim Schreiben von CSS bezüglich Border achten müssen" class="aBlack">Zusammenfassung dessen, worauf Sie beim Schreiben von CSS bezüglich Border achten müssen</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/961.html" title="So realisieren Sie die Auswahl mehrerer Stile und den Echtzeitwechsel von Stilen. Erleben Sie den Austausch" class="aBlack">So realisieren Sie die Auswahl mehrerer Stile und den Echtzeitwechsel von Stilen. Erleben Sie den Austausch</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/1345.html" title="Detaillierte Nutzungsanalyse von Marquee" class="aBlack">Detaillierte Nutzungsanalyse von Marquee</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/269082.html" title="CSS标题线(删除线贯穿线效果)实现" class="aBlack">CSS标题线(删除线贯穿线效果)实现</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/269606.html" title="CSS3中优雅降级和渐进增强的区别" class="aBlack">CSS3中优雅降级和渐进增强的区别</a><div class="clear"></div></li></ul></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-5902227090019525" data-ad-slot="5027754603"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!</p></div><div class="footermid"><a href="https://m.php.cn/de/about/us.html">Über uns</a><a href="https://m.php.cn/de/about/disclaimer.html">Haftungsausschluss</a><a href="https://m.php.cn/de/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body><!-- Matomo --><script> var _paq = window._paq = window._paq || []; /* tracker methods like "setCustomDimension" should be called before "trackPageView" */ _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u="https://tongji.php.cn/"; _paq.push(['setTrackerUrl', u+'matomo.php']); _paq.push(['setSiteId', '9']); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s); })(); </script><!-- End Matomo Code --></html>