- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我目前正在做一个网站。在学习了 HTML5 及其特性之后,我想继续使用它。我想使用离线存储、数据属性、简单聊天支持等功能,但由于 HTML5 还没有得到很好的支持,我有点困惑。直到现在我一直使用 XHTML 1.0 transitional;我应该继续使用它还是应该使用 HTML5?
我看到像 google 这样的网络巨头已经完全转向 HTML5。
最佳答案
如果您指的是 HTML5 功能,那么您必须了解 HTML5 的真正含义。我会定义它具有以前规范的顶点以及更新和更丰富的功能。它旨在支持现有内容(向后兼容)并支持创建 Web 应用程序。真正令人敬畏的是它不仅止于此。它首次规定了浏览器应该如何处理错误。
现在,您需要知道并非所有功能都在浏览器中实现。你可以拿HTML5 browser test知道什么有效,什么无效。这并不意味着它们不起作用!大多数浏览器实际上允许您使用和设计您想要发明的任何元素。新的 HTML5 标签在不支持它们的浏览器中没有默认样式。
以下 CSS 代码对于大多数浏览器来说就足够了:
section, article, header, footer, nav, aside, hgroup {
display: block;
}
一如既往,Internet Explorer (IE) 有特殊需求。只是,有一位名叫 Remy Sharp 的 JavasScript 魔术师创建了一个 JavaScript 文件,该文件为 IE 创建了每个元素。所以你可以在你的页面中添加这个:
<!--[if IE]>
<script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"
</script>
<![endif]-->
顺便说一下,您将不得不使用 JavaScript 来测试新的 HTML5 元素是否存在,并为那些浏览器不能适应某些 HTML5 元素和属性的用户提供替代选择。这就是为什么有这个小的通用 JavaSCript 函数,您可以使用它来做到这一点:
function elementSupportsAttribute(element, attribute) {
var test = document.createElement(element);
if(attribute in test)
return true;
else
return false;
}
最后一点,我从书中获得了大部分信息 HTML5 For Web Designers .感谢 Jeremy Keith!
如果您指的是新文档类型 one <!DOCTYPE HTML>
,这就是我要说的......
在 HTML5 中使用以前 HTML/XHTML 版本的功能并不违法。请注意,新文档类型没有任何与之关联的数字。这是因为它旨在建立在现有规范的基础上并对 future 版本有效。因此,我建议您使用新的文档类型。
你可以看看spec在 W3C 网站上。简而言之,规范是这样说的……
8.1.1 The DOCTYPE
A DOCTYPE is a required preamble.
DOCTYPEs are required for legacy reasons. When omitted, browsers tend to use a different rendering mode that is incompatible with some specifications. Including the DOCTYPE in a document ensures that the browser makes a best-effort attempt at following the relevant specifications.
[...]
For the purposes of HTML generators that cannot output HTML markup with the short DOCTYPE "
<!DOCTYPE html>
", a DOCTYPE legacy string may be inserted into the DOCTYPE (in the position defined above).
关于html - 应该为公共(public)网站选择哪个 HTML 版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4760882/
我正在尝试在Elasticsearch中返回的值中考虑地理位置的接近性。我希望近距离比某些字段(例如legal_name)重要,但比其他字段重要。 从文档看来,当前的方法是使用distance_fea
我是Elasticsearch的初学者,今天在进行“多与或”查询时遇到问题。 我有一个SQL查询,需要在Elastic中进行转换: WHERE host_id = 999 AND psh_pid =
智能指针应该/可以在函数中通过引用传递吗? 即: void foo(const std::weak_ptr& x) 最佳答案 当然你可以通过const&传递一个智能指针。 这样做也是有原因的: 如果接
我想执行与以下MYSQL查询等效的查询 SELECT http_user, http_req_method, dst dst_port count(*) as total FROM my_table
我用这两个查询进行测试 用must查询 { "size": 200, "from": 0, "query": { "bool": { "must": [ { "mat
我仍在研究 Pro Android 2 的简短服务示例(第 304 页)同样,服务示例由两个类组成:如下所示的 BackgroundService.java 和如下所示的 MainActivity.j
给定标记 like this : header really_wide_table..........................................
根据 shouldJS 上的文档网站我应该能够做到这一点: ''.should.be.empty(); ChaiJS网站没有使用 should 语法的示例,但它列出了 expect 并且上面的示例似乎
我在 Stack Overflow 上读到一些 C 函数是“过时的”或“应该避免”。你能给我一些这种功能的例子以及原因吗? 这些功能有哪些替代方案? 我们可以安全地使用它们 - 有什么好的做法吗? 最
在 C++11 中,可变参数模板允许使用任意数量的参数和省略号运算符 ... 调用函数。允许该可变参数函数对每个参数做一些事情,即使每个参数的事情不是一样的: template void dummy(
我在我从事的项目之一上将Shoulda与Test::Unit结合使用。我遇到的问题是我最近更改了此设置: class MyModel :update end 以前,我的(通过)测试看起来像这样: c
我该如何做 or使用 chai.should 进行测试? 例如就像是 total.should.equal(4).or.equal(5) 或者 total.should.equal.any(4,5)
如果您要将存储库 B 中的更改 merge 到存储库 A 中,是否应该 merge .hgtags 中的更改? 存储库 B 可能具有 A 中没有的标签 1.01、1.02、1.03。为什么要将这些 m
我正在尝试执行X AND(y OR z)的查询 我需要获得该代理为上市代理或卖方的所有已售属性(property)。 我只用 bool(boolean) 值就可以得到9324个结果。当我添加 bool
我要离开 this教程,尝试使用 Mocha、Supertest 和 Should.js 进行测试。 我有以下基本测试来通过 PUT 创建用户接受 header 中数据的端点。 describe('U
我正在尝试为 Web 应用程序编写一些 UI 测试,但有一些复杂的问题希望您能帮助我解决。 首先,该应用程序有两种模式。其中一种模式是“训练”,另一种是“现场”。在实时模式下,数据直接从我们的数据库中
我有一个规范: require 'spec_helper' # hmm... I need to include it here because if I include it inside desc
我正在尝试用这个测试我在 Rails 中的更新操作: context "on PUT to :update" do setup do @countdown = Factory(:count
我还没有找到合适的答案: onclick="..." 中是否应该转义 &(& 符号)? (或者就此而言,在每个 HTML 属性中?) 我已经尝试在 jsFiddle 和 W3C 的验证器上运行转义和非
import java.applet.*; import java.awt.*; import java.awt.event.*; public class Main extends Applet i
我是一名优秀的程序员,十分优秀!