专栏首页狮乐园HTML is about meaning

HTML is about meaning

原文地址: http://marksheet.io/html-semantics.html

HTML标签本身的意义是为了传递对于一个document元素的含义,所以再考虑使用正确的标签表达内容之前,考虑你的网页看起来怎么样为时过早,请将注意力集中到每一个你使用的HTML标签上。

你需要根据你书写的内容及本文本身的含义,来选择与之匹配的HTML标签。

Structure elements: 组织页面

你可以使用结构元素来组织页面的主要部分,这些部分通常包含其他的HTML元素。

下面是一个典型的网页需要包含的主要部分:

  • <header>作为页面的第一个元素,包含logo和tagline。
  • <nav>作为跳转到其他不同的页面的超链接集合。
  • <h1>作为页面的标题。
  • <article>作为页面的内容模块,比如blog的一个post。
  • <footer>作为页面的最后一个元素,位于最底部。

Text elements: 定义内容

在结构元素中,通常需要寻找一些文本元素来达到定义内容的目的。

你将主要使用如下标签:

  • <p>作为段落
  • <ul>作为无序列表
  • <ol>作为有序列表
  • <li>作为列表单元
  • <blockquote>作为引用

Inline elements: 区分文本

因为文本标签通常会很长,并且会有不同的内容,行内元素使你可以将一些关键部分从文本中区分出来。

有很多的行内元素可以使用,但是你会经常用到以下几个:

  • <strong>作为关键字
  • <em>作为强调字
  • <a>作为超链接
  • <small>作为次要字
  • <abbr>作为缩写

尝试阅读下面的HTML代码,你就可以很容易的理解每一个元素的用途。

<article>
  <h1>Main title of the page</h1>
  <h2>A subtitle</h2>
  <p>
    Something something an other stuff and some <em>emphasis</em> and even <strong>important</strong> words.
  </p>
  <p>
    Another paragraph.
  </p>
  <ul>
    <li>One</li>
    <li>Two</li>
    <li>Three</li>
  </ul>
  <blockquote>
    Once said
  </blockquote>
</article>
<aside>
  <h3>My latest posts</h3>
  <ul>
    <li><a href="#">One</a></li>
    <li><a href="#">One</a></li>
    <li><a href="#">One</a></li>
  </ul>
</aside>

Generic elements 演变标签

当没有显而易见的具有语义的标签来匹配相关内容,但你仍然要插入一些标签来达到格式化和分组化的目的,你可以使用一到两个下面的具有演变性的标签:

我理解的演变的意思是这些标签可以通过css样式来变成不同职能的其他标签

  • <div>作为块级元素组
  • <span>作为行内元素组

尽管这些标签没有任何的实际意义,但它们与css配合使用将十分有用。

Don’t overthink semantics 不要想太多

大约有100多种语义标签供你使用。如果可以选择合适的元素来使用,那将是十分不错的选择。

但是不要花费太多的事情太考虑这件事,仅仅从现在开始,有选择地使用上面所提供的标签,你的网页将会变得更好。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • interview record 20160822

    问了一些列范围超级广的问题,不过我感觉大部分问题的答案,面试官还是比较满意的,有一些小问题没有答上来,我觉的并不是因为自己没有能力,其实就是所谓的“约书亚树”道...

    littlelyon
  • 13 个设计 REST API 的最佳实践

    之所以翻译这篇文章,是因为自从成为一名前端码农之后,调接口这件事情就成为了家常便饭,并且,还伴随着无数的争论与无奈。编写友好的 restful api 不论对于...

    littlelyon
  • liferay-progress-bar

    上次山寨了一个smile face,最近因为一直都在测70,然后就又对70的progress bar起了兴趣。

    littlelyon
  • python爬虫常用库之BeautifulSoup详解

    这是日常学python的第16篇原创文章 经过了前面几篇文章的学习,估计你已经会爬不少中小型网站了。但是有人说,前面的正则很难唉,学不好。正则的确很难,有人说...

    sergiojune
  • Beautiful Soup (一)

    1、Beautiful Soup库可以说是对HTML进行解析、遍历、维护“标签树”的功能库

    小麦苗DBA宝典
  • JQuery笔记(三) jquery的用途

      近期jquery的学习经历了一些反复:开始时觉得非常强大,比js好用,和css关系密切,一句话:完美。等到把《锋利的JQuery》看完,又有点不知道用它来干...

    用户1075292
  • 从零开始学Web之HTML(二)标签、超链接、特殊符号、列表、音乐、滚动、head等

    文本倾斜:<em></em> <i></i> <!-- 工作里尽量使用em,原因同strong -->

    Daotin
  • <bdi>标签

    Html5知典
  • 【小知识】小例子说明Spring的核心思想之一:控制反转。

    目的:改写已存在的类的某个方法或某些方法,使方法增强了。装饰设计模式(也即包装设计模式) 口诀:

    黑泽君
  • 快速学习-Kafka API

    Kafka 的 Producer 发送消息采用的是异步发送的方式。在消息发送的过程中,涉及到了两个线程——main 线程和 Sender 线程,以及一个线程共享...

    cwl_java

扫码关注云+社区

领取腾讯云代金券