上次我写了关于我喜欢的HTML5格式,在后续的文章中我会写关于我所讨厌的HTML和HTML5文件格式,他们都是在开发我们的网站和PDF与HTML5转换器中会花费大量时间的工作。
首先,我想简单概括一下为什么HTML5会在这个智能手机和平板电脑风靡的时代,变成一种解决现代需求和网站需求的新标准,废话不多说,下面就让我们开始吧!
那么什么是HTML5呢?
HTML5是HTML标准的最新版本,它是一个专门用于构建互联网并展示出万维网内容的核心标记语言。HTML5在HTML4的基础之上增加了新的标签如<video>,<audio>,<canvas>,以及矢量图形内容整合,另外还有一些数学公式的标记语言。这些新的功能会让我们在不需要安装专门的插件和接口的情况下,在网络上更好的呈现出多媒体和图形界面的内容。一个很好地案例就是Youtube,它的视频现在都是用HTML5来展示。
现在已经了解了什么是HTML5以及它的一些功能特征,你可能想知道,既然HTML5这么好你为什么还讨厌它呢?
接下来我将会告诉你为什么…
1、不支持TIFF格式我很讨厌的一点是在HTML5中不支持TIFF格式。
什么是TIFF呢?它是一个位图图像文件格式,经常被用于专业的高品质图像的存储、转换、显示以及剪贴画,扫描文件等光栅图像的打印。由于TIFF专门设计用于栅格数据的转换,是一种在印刷行业中得到广泛支持的图形文件格式,它能够作为高品质图像的大型调色板使用。TIFF允许颜色分辨率高达48位RGB颜色或是为64K的调色板。
更好的图形缩放意味着使用它进行图形绘制和图像编辑将会更加顺利,并适合在postscript打印机和非postscript打印机上面运行,是一种最好的归档图像的格式。
看到了TIFF格式的这么多好处你肯定也会认为HTML5应该会支持TIFF格式,不幸的是只有Safari作为TIFF文件的原生支持,其它的任何浏览器并不支持TIFF。
2、兼容性问题关于HTML5我最讨厌的就是它的不兼容。虽然每次浏览器更新都能修复一些不兼容,有时候某个修复还可能会破坏另一个修复。例如在CSS中或者嵌入内容和HTML5功能设置中的某些Bug。
下面的截图很好地展示了各种浏览器对HTML5输入字段的模式属性的支持。可以看出,安卓和IE浏览器的最新版本在支持HTML5上面还有一些问题。而Safari只有部分支持HTML5,如果你在你的网站上使用HTML5,你会发现它不会被很好地展示。
事实上很多的浏览器在HTML5的支持上都有问题,下面的图片显示了每个浏览器对HTML5的支持程度。令人惊讶的是不是所有的HTML5规范都被所有浏览器支持。
和HTML5一样,Web视图也有一些轻微的不兼容。由于屏幕大小的不同、终端用户操作系统的差别以及缺乏标准等诸多因素,兼容性了安卓系统上的一个很严重的问题。虽然兼容性问题能通过安装新版本来解决,但不是所有的设备都支持最新的更新,如果是一个Web App的话将面临一个更严重的问题。3、谷歌更新问题鉴于在计我们的网站和开发PDF与HMTL5转换器的过程中会花费很多时间在HTML5上面,我经常会发现每次谷歌更新会修复一个问题,但也会破坏一些东西。以前谷歌破坏了HTML5游戏和HTML5滚动条。快速地看一下谷歌,你会发现其他人也有同样的问题。
4、易于扩散HTML5可以嵌入视频,音频,文字,高质量的图像,动画和互动的应用程序直接进入网页,对第三方插件的依赖将减少。
主要是从图像大小,CSS,Javascript和一般的HTML5推动至他们的极限。添加更多的HTML5基础代码,让那些连接速度慢或者有数据限制的移动用户获取更多的HTML5的传播和扩散。
5、支持传统的CSS一个我比较讨厌的关于HTML5的事情是它支持传统的CSS。你曾建立过一个不错的网站然后发现他在谷歌、火狐、Opera和Safari中运行的很好但是却不能在IE浏览器中运行吗?有一些工作区像回退方法或者专门教你在旧版浏览器中处理这些问题。但是除非你在HTML5代码中特别指定,否则的话它将不会很快修复这些问题。
6、缺乏表单的验证最后要说的是关于HTML5我最讨厌的就是它缺乏表单验证
通过包含一个内置的客户端表单验证机制的设计使执行客户端无缝验证,从而使HTML5支持表单验证。但是,人们避免HTML5表单验证最主要的原因是缺乏新的应用程序接口的浏览器支持。
不幸的是,任然有很大的一部分用户群还在使用不支持新的应用程序接口的浏览器,所以如果你打算迎合这些用户,最终你不得不添加工作区到你的代码中,以便获得所有的浏览器支持。但是这会耗费一些时间和精力去保留多个代码路径。
最后希望这篇文章能够对你有用。如果你也遇到过同样的关于HTML5格式问题的困扰?请告诉我。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。