- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
HTML5(或更准确地说是新的 HTML 规范)最受关注的方面之一是添加了 <section>
。 , <article>
, <aside>
等。目标是引入一种新的轮廓算法。例如,以下文档:
<h1>Types of dogs</h1>
<section>
<h1>Doberman</h1>
<aside>
<h1>Advertisement</h1>
</aside>
</section>
应该产生这个大纲:
1. Types of dogs
1. Doberman
1. Advertisement
理论上,<aside>
不应该是主要大纲的一部分,但是gsnedder's tool无论如何包括它。此外,众所周知,在用户代理中不存在此算法的实现1。这阻止了我采用这些标签。虽然它们将是“最佳实践”,因为它们比 <div>
添加了更多的“语义”含义。 ,使用这些标签构建文档的方式(以保留实际预期的大纲)会破坏目的。通过谨慎使用 header 标签、源代码本身的信息结构和 CSS 可以达到相同的效果。
是否有充分的理由使用这些标签?
1:来源MDN和 www.w3.org/TR/html5/sections.html(尽管 W3 喜欢编辑 WHATWG 规范,但它仍然是半权威的)
最佳答案
文档大纲和语义是两个独立的问题。你是正确的,因为不存在面向用户的大纲实现——唯一的实现是在专门为此目的创建的工具和一致性检查器中。这就是规范建议继续使用 h1–h6 来标记标题的原因。
但如今,HTML5 语义本身已在现代浏览器和无障碍工具中广泛实现。一些 HTML5 语义元素甚至为您内置了 ARIA 角色。查看ARIA in HTML spec , caniuse.com ,以及 this test (caniuse.com 本身链接到)。
比较以下片段(更改标题以说明缺少大纲算法):
<h1>Types of dogs</h1>
<section>
<h2>Doberman</h2>
<aside>
<h3>Advertisement</h3>
</aside>
</section>
<h1>Types of dogs</h1>
<div class=section>
<h2>Doberman</h2>
<div class=ad>
<h3>Advertisement</h3>
</div>
</div>
如果您需要支持不理解 HTML5 的用户代理,您可以只填充元素,或者使用旧标记。无论哪种方式,这两个片段对于那些用户代理来说在语义上都是毫无意义的。
如果您不需要支持旧版浏览器,则第一个片段在语义上是有意义的,而第二个片段……不是这样。无论您如何命名类名,类名都没有任何内在的语义值(value)——它们的存在只是为了方便作者。充其量,您所拥有的只是一系列通用部分和小节。广告部分中的 h3 与内容子部分中的 h3 没有区别。
当然,人类读者仍然可以通过查看类名从元素中推断出含义,但是将所有内容都放在 div 中会非常非常快地变得困惑。
坦率地说,除了支持旧版浏览器外,我想不出有什么理由在今天的新站点中使用旧版标记。如果有的话,HTML5 语义标记应该是默认的。请记住,内容为王,我们正在处理一种专为网络内容设计的语言。但我很快就转向了自以为是的领域。
请注意,我在这里没有提到 CSS。那是因为在谈论语义标记时,CSS 是完全不相关的。当您的文档独立于任何 CSS 使用时,语义最有效。
关于html - 使用 <section> 等有什么意义吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35388136/
这个问题在这里已经有了答案: Multi level categories with items on all levels in UITableView (1 个回答) 关闭 6 年前。 标题说明
我想在编译时从代码中删除未使用的函数。然后我写一些代码(main.c): #include const char *get1(); int main() { puts( get1() );
升级到 Xcode 4.4 后,当我尝试在 iPhone 或 iPad 上运行我的(通用)应用程序时,我遇到了这个烦人的链接器错误。如果我在 iOS 模拟器上运行它,我没有问题... 我尝试添加 ar
我以前从未见过这个错误,我搜索了它可能发生的原因,但找不到任何相关信息: CoreData: error: Serious application error. An exception was ca
我正在使用以下内容填充 UITableView 部分的各个部分: fetchedResultsController = NSFetchedResultsController(fetchReques
是标签允许包含在另一个 中标签?它会在 HTML5 中验证吗? 最佳答案 Yes ! w3 鼓励您在分节内容的元素中显式包装节,而不是依赖于在分节内容的一个元素中包含多个标题而生成的隐式节,并且允许
我使用部分来确定页面的不同部分。这些部分的底部边距为 90px,但是当在页面中创建/放置 ID 为“clients-full”的部分时,我希望出现在它之前/上方的任何部分的底部边距为 0。我可以做吗这
我现在有一个第三方提供的c静态库(用arm-gcc编译的)。我不可能(让第三方)重新编译库。 在调查库内容时,我发现 gcc 选项 -ffunction-sections 和 -fdata-secti
大家好,我陷入了一个奇怪的问题,我正在重新加载 tableViewSection,它正在正确地重新加载该部分,但它隐藏了其他部分,直到我向上或向下滚动它。我使用以下代码重新加载 func tabl
在我的项目中,我有扩展 ArrayAdapter 的类并实现 SectionIndexer .实现方法时getPositionForSection和 getSectionForPosition我发现了
我正在尝试编译 scss,以便在它具有 class1 时获得该部分。我不知道如何去做,因为我得到了空间,而且它的工作方式不一样。 当前输出: .class2 > section .class1 {
我正在阅读 Mark Pilgirm 的“Dive into HTML5”和 semantics section ,它讨论了 HTML5 如何引入 和 元素。它说 s 代表通用文档或部分,而 s
我是使用ARM编译器进行Keil Microvision V5.12编程的新手。 我无法编译一个简单的组装项目,但出现此错误: .\Objects\learn.sct(7): error: L6236
这是我第一次在这里问问题,但我不得不说这个网站在过去几个月里给了我巨大的帮助(iphone-dev-wise),我为此表示感谢。 但是,我没有找到解决这个问题的方法:我有一个包含 2 个部分的 UIT
我在 IOS 中实现了一个 TableView (4 个部分)。问题是我刚刚在第一部分添加了一个部分标题。其他部分没有标题。第一部分没有行(行数为 0)。其他部分有多行。当我滚动时,第一部分的标题不粘
我有一个包含多个部分的表格 View 。我希望能够将行从一个部分移动到另一个部分,并在没有行时删除一个部分。我正在尝试通过 moveRowAtIndexPath 执行此操作,但我的代码不起作用并抛出
我正在尝试删除不符合 for 循环条件的行。但是,我收到错误消息:“尝试从第 1 部分删除第 0 行,但更新前只有 1 个部分。”我以前从未见过这个,也不确定为什么会收到它。 我的代码: func
GCC 页面中针对功能部分和数据部分选项的以下内容: -ffunction-sections -fdata-sections Place each function or data item into
我想在安装新数据库之前删除旧数据库,以便为用户更新它。 我有以下情况: 在我的 Components 部分中,我为用户提供了一个选项: [Components] Name: "updateDataba
我从工作区添加了一个测试用例。可能已经一周了,所以我不记得它是来自 Backlog 还是来自董事会。 现在,当我进入测试/测试计划时,它没有出现。我找不到将其添加到测试套件的方法。 我可以通过测试区域
我是一名优秀的程序员,十分优秀!