《HTML5和CSS3快速参考》——2.2 XHTML5

简介:

本节书摘来自异步社区《HTML5和CSS3快速参考》一书中的第2章,第2.2节,作者: 【美】Sergey Mavrody 更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.2 XHTML5

支持多种语言的HTML文档
在多语言环境下,HTML文档既是一份有效的HTML文档,也是一份有效的XHTML文档。

  • 在多语言环境下,HTML文档同时遵守HTML和XHTML的语法规则,即它所采用的语法是HTML和XHTML语法的交集。
  • 一份多语言文档能同时提供HTML和XHTML两种服务,具体取决于浏览器的支持及其MIME类型。
  • 至于是否要在HTML中选择多语言环境,则取决于具体的项目需求、浏览器的支持以及其他可能的影响。
<!--HTML4, HTML5 syntax-->
<input disabled>
<input disabled=disabled>
<!--XHTML 1.0 syntax-->
<input disabled=“disabled” />
<!--HTML4, HTML5, XHTML 1.0
conforming Polyglot syntax-->
<input disabled=“disabled” />

XHTML5中的定义操作
一份多语言版的HTML5代码基本上等同于一份XHTML文档(只要提供相应的XML MIME类型[application/xhtml+xml]即可)。总而言之,在多语言环境的HTML5文档中:

应声明HTML5 DOCTYPE/namespace。尽管HTML5已经不再需要进行DTD(Document Type Definition)了(因为其格式已经不再基于SGML了),但对于DOCTYPE,我们依然得保留一定的向后兼容性。

应具有更良好的XHTML语法。

尽管多语言版的HTML文档同时提供了HTML和XHTML两种服务,但其实际运作仍需取决于浏览器的支持以及其自身的MIME类型。单纯就理论而言,一份支持多语言的HTML5代码基本就等同于一份XHTML5文档(只要它声明了XML MIME类型:application/xhtml+xml)。总体上,对于XHTML5文档而言:

  • 如果默认编码是UTF-8的话,其XML声明(<?xml version=”1.0” encoding=”UTF-8”?>)就不是必须的。
  • 其HTML DOCTYPE,即声明也是可选的。但它在多语言版的HTML或XHTML文档中均可使用。
  • 应具有更良好的XHTML语法。
  • 应声明其XML MIME类型:application/xhtml+xml。此MIME声明在源代码中是不可见的,但它在配置浏览器处理相关HTTP头Content-Type信息时有着非常重要的作用。尽管XML MIME类型还不为IE浏览器的当前版本所支持,但该浏览器依然是可以解析XHTML文档的。
  • XHTML的默认命名空间为 xmlns=”
http://www.w3.org/1999/xhtml”>。另外,文档还支持某些辅助命名空间,如SVG、MathML、Xlink等。对我来说,这些是测试所需的,但如果你的文档中不需要用到这些命名空间,那么使用XHTML就有些杀鸡用牛刀的感觉了。当然,无论你选择的是HTML还是XHTML,本质上还是其媒体类型所决定的。

最终,一份基本的HTML5文档看上去应该是这个样子:

在这里,XML声明<?xml verstion="1.0" encoding="UTF-8" ?>并不是必须的。只要我们的默认编码是UTF-8,XHTML验证器不会在意它被忽略。

但是,我们还是强烈建议你在服务器端用HTTP Context-Type头信息来配置文档的编码,否则字符编码可能就会由每个文档自身的某一部分来决定(meta标签:)。

而这种编码声明本身就需要在一份多语言版的文档中进行。因此,如果该文档要同时适用于HTML和XHTML两种服务,编码也就默认为UTF-8。

<!DOCTYPE html>
<html xmlns=“http://www.w3.org/1999/xhtml”>
<head>
  <title></title>
  <meta charset=“UTF-8” />
</head>
<body>
  <svg xmlns=“http://www.w3.org/2000/svg”>
  <rect stroke=“black” fill=”blue”
x=“45px” y=“45px” width=“200px”

另外,我们还可以通过Total Validator工具(包括Firefox插件版和桌面版)对当前用户选中的项目进行XHTML5规则验证。

height=“100px” stroke-width=“2”/>
  </svg>
</body>
</html>

XHTML5的主要作用是对HTML5进行扩展,使其能运用SVG、MathML这类基于XML的技术。尽管HTML5规则已经支持了SVG和MathML这些内联技术,但目前浏览器对它们的实际支持是相当有限的。事实上,这项技术的缺点也正是它在IE上缺少足够的支持,以及其在代码要求和错误处理方面也更为烦琐。因此除非我们真的需要这些扩展,否则HTML5就已经足够了。

归根结底,HTML5与XHTML5之间的选择实际上已经落在了MIME/content类型上面,我们对于文档类型的决定已经和XHTML1 vs. HTML4时代不一样了,XHTML5 vs. HTML5时代选择本质上将取决于MIME类型,而不是DOCTYPE。

相关文章
|
28天前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
78 6
|
30天前
HTML 属性参考手册
HTML属性参考手册提供了常用的HTML属性列表,包括`class`、`id`、`style`、`title`等,用于定义元素的样式、唯一标识、额外信息等。此外,还包括`href`、`src`、`alt`、`name`、`value`、`target`、`type`和`placeholder`等,分别用于链接、资源路径、替代文本、表单元素名称和值、链接打开方式、表单元素类型及占位符文本的定义。
|
12天前
HTML - XHTML5
在HTML中,不应使用属性简写形式。
|
27天前
|
前端开发
HTML 样式- CSS3
内部样式表适用于单个文件的特别样式,通过&lt;head&gt;部分的&lt;style&gt;标签定义;外部样式表适用于多个页面,通过&lt;link&gt;标签引用外部CSS文件;&lt;style&gt;定义样式,&lt;link&gt;引用资源;已弃用的标签有&lt;font&gt;、&lt;center&gt;、&lt;strike&gt;,属性有color和bgcolor。
WK
|
2月前
|
存储 移动开发 前端开发
HTML5和CSS5有什么区别
HTML5和CSS5在网页设计中扮演不同角色。HTML5是超文本标记语言的第五版,通过新特性如实时更新、跨平台运行及更好的安全性等,定义网页内容和结构。尽管常说CSS5,实际最新的CSS版本包含多个模块如CSS Grid和Flexbox,主要用于控制网页布局和样式,提供强大的选择器、动画支持和响应式设计,与HTML5相辅相成,共同构建现代网页的基础架构。
WK
51 3
|
3月前
|
移动开发 JavaScript 前端开发
揭秘!如何用Web2py+HTML5/CSS3/jQuery打造超炫响应式网站?你的设计梦想即将照进现实!
【8月更文挑战第31天】本文详细介绍如何利用Web2py框架及HTML5、CSS3与jQuery构建响应式网站。首先需安装Python和Web2py,并启动服务器。接着,在Web2py中创建新应用,例如命名为“ResponsiveSite”。随后,编写HTML5基本结构,包括头部、导航栏等元素。在`styles.css`文件中添加CSS3样式代码,实现响应式布局。最后,通过在`scripts.js`中加入jQuery脚本提升页面交互性,如点击导航项时平滑滚动至目标区域。此教程为你打下响应式网站设计的基础,便于进一步扩展和优化。
32 1
|
3月前
|
移动开发 前端开发 JavaScript
大气实用的HTML5/CSS3个人中心页面(含源码)
大气实用的HTML5/CSS3个人中心页面(含源码)
|
3月前
|
Java 数据安全/隐私保护 安全
掌握Struts 2动态方法调用,让你的Web开发如虎添翼,轻松应对复杂业务需求!
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活性而广受青睐。其动态方法调用(DMI)特性允许在不修改配置文件的情况下动态调用Action类中的方法,相比传统方法调用(需在`struts.xml`中为每个方法创建单独的`&lt;action&gt;`),DMI简化了配置并提升了灵活性、可维护性和扩展性。本文通过对比DMI与传统方法调用,展示如何利用DMI简化开发流程,并强调了在使用DMI时需注意的安全性和访问控制问题。
47 0
|
3月前
|
前端开发 Ubuntu Linux
CSS 系统字体堆栈参考
CSS 系统字体堆栈参考
35 0
|
4月前
|
前端开发 JavaScript
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法