转一篇非常好的IE兼容文章-兼容IE6\7\8浏览器的html5标签的几个方案

html5大行其道的时代已经到来。如果你还在等待浏览器兼容,说明你已经与web脱节几条街了。当然,这得益于移动客户端的蓬勃发展。如果还在纠结于,是否应该掌握html5和css3技术时,请狠狠的抽自己几个嘴巴,然后,苦学吧!因为前端的春天已经到来,而且不止一个春天。如果你不信,我只能说:爱信不信!

下面我们来看一个标准的html5标签结构:(我这里只是说标签,其它概不涉及)

<!DOCTYPE HTML>
<html>
<head>
<meta charset="gb2312">
<title>html5</title>
</head>

<body>
    <header>
        <nav></nav>
    </header>
    <article>
        <section>
            <h2></h2>
            <p></p>
        </section>
    </article>

    <footer></footer>
</body>
</html>

html5标签的进步之处当然于它的语义化更直观。当然,这只是html5的进步的九牛之一毛,有人建议说:不要说html5的进步是革命性的,而是发展性的!我不反对此说法,但某方面的确是革命性的。这里不想跑题,我们只说标签。
当然,兴奋于如此美妙的语义化标签时,不仅仍要追问:IE支持吗?很不幸,答案是否定的。如果你已经被IE搞怕了,你只得继续忍受它无尽的折磨。(IE9和IE10已经兼容支持html5和css3.0)

不过你要庆幸,你生活的这个时代有很多天才。有人已经帮你把这个问题解决了!虽然,不能称上完美!

下面我们来看几个解决兼容IE6\7\8不支持html5标签的几个方法:

1、javascript: document.createElenment("......")

  IE6\7\8不支持的部分原因是,它们不认为footer是一个有效的html标签。那么我们把它“制造”成一个标签不就行了吗?最直接的办法当然是,javascript 的方式创建:document.createElenment("......")!

(function(){
            var element=['header','footer','article','aside','section','nav','menu','hgroup','details','dialog','figure','figcaption'],
                len=element.length;
            while(len--){
                document.createElement(element[i])
            }
 })();

这只是简单创建几典型的html5标签,让它们在IE6\7\8可以成为标签。
有人已经写了一个完整的js文件,你只需要引入既可,像这样:

<!--[if lt ie 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]--> 

也有写作

<!--[if lte IE 9]>
    <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
< ![endif]-->

html5shiv和html5shim的区别只有"m"和"v",没有其它区别!当然这不是我说的。原文是:...the only difference is that "one has an m and one has a v - that's it."

这里要做一个特别的说明:就是IE特有的注释判断:

lte:就是Less than or equal to的简写,也就是小于或等于的意思。

lt :就是Less than的简写,也就是小于的意思。

gte:就是Greater than or equal to的简写,也就是大于或等于的意思。

gt :就是Greater than的简写,也就是大于的意思。

! : 就是不等于的意思,跟javascript里的不等于判断符相同

因为IE9虽然支持html5标签,但支持的不是很完整,所以,也可以写"lte",这取决于你的选择!

当然,不要忘了指定新建标签的display属性,大多情况下我希望标签是block的:

header,footer,article,aside,section,nav,menu,hgroup,details,dialog,figure,figcaption{display:block}

 2、嵌套标签的方法

其实说白了就是在,语义化的html5标签内嵌套div等可用标签,然后只给div写样式,我是不赞成这样的写法的。这样做还不如,给标签一个有语义化的id或者class!

<!--[if lt IE 9]>
<style>
body > * .section {
    color: #ff0;
}
</style>
<![endif]-->
<style>
section .section {    color: #f00;
}
</style>
<section><div class="section">内容测试...</div></section>

但如果类似于这样的结构,用用也无防:

<nav >
        <ul class="test">
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </nav>

3、IE条件注释

<!--[if lt IE 9]><div class="section"><![endif]-->
<!--[if IE 9]><section class="section"><![endif]-->
<!--[if !IE]><!--><section class="section"><!--<![endif]-->
    ......
<!--[if lt IE 9]></div><![endif]-->
<!--[if IE 9]></section><![endif]-->
<!--[if !IE]><!--></section><!--<![endif]-->

再看一遍IE特有的注释判断:

lte:就是Less than or equal to的简写,也就是小于或等于的意思。

lt :就是Less than的简写,也就是小于的意思。

gte:就是Greater than or equal to的简写,也就是大于或等于的意思。

gt :就是Greater than的简写,也就是大于的意思。

! : 就是不等于的意思,跟javascript里的不等于判断符相同

相信大家都明白,这是怎么回事!这是一个更加蛋疼的办法!大量的html代码使原本想语义化的代码更加混乱不堪。而且要对样式的书写也不利。

4、使用xmlns定义文档的命我空间

xmlns即是XHTML namespace的缩写,也就是所谓的“命名空间”。与DOCTYPE声明一样,xmlns也属于一种声明。与HTML文档中仍然存在DOCTYPE声明不一样的是,在HTML文档是不存在xmlns的,我们平常所见到的xmlns都是出现在XHTML文档中的。

<html xmlns="http://www.w3.org/1999/xhtml" lang="en"> 

这是xhtml原有的命名空间,到了html5以后被简化了,。

<html lang="en">

来自Elco Klingen日志的方法一开始引起了广泛的关注。该技术包含了一个XML形式的命名空间,并使用了含有namespace前缀的元素,例如:

<!DOCTYPE HTML>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:html5="http://www.w3.org/html5/">
<body>
 <html5:section>
 <!-- content -->
 </html5:section>
</body>
</html>

:html5这个前缀并不是一个标准的写法,你也可以用其它字符代替:hl5也是可以的。有了前缀之后,IE会识别新的元素,从而可以应用样式。在其他浏览器中一样有效,那么最后,你就成功地在各个浏览器中构建了一样的元素和一样的样式。

这个方法很明显有个缺陷:你必须在HTML文档中使用XML格式的命名空间,同样,你也需要在css中这么做:

html5\:section {
 display: block;
}

那么对js的兼容性如何呢?下面是个测试demo

<!DOCTYPE HTML>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:html5="http://www.w3.org/html5/">
<head>
<title>;html5</title>
<meta charset="gb2312">
<style>
    html5\:section { display: block; width:100px; height:50px; background:#f00; border: 1px solid blue; color: #ff0; }
</style>
<script>
  window.onload = function(){
     alert(document.getElementById("test").innerHTML + "---id")
     alert(document.getElementsByTagName("section")[0].innerHTML + "---TagName")
     alert(document.getElementsByTagName("SECTION")[0].innerHTML + "---大写")
  }
</script>
</head>
<body>
    <html5:section id="test">内容</html5:section>
</body>
</html>

测试结果,IE6\7\8均测试通过,但fixfox和chrome里只有id能获取到,所以这种方法同样不是一个可取的方法!

时间: 2024-07-29 07:34:12

转一篇非常好的IE兼容文章-兼容IE6\7\8浏览器的html5标签的几个方案的相关文章

360浏览器不兼容-关于图片滚动在不同浏览器中部兼容的问题

问题描述 关于图片滚动在不同浏览器中部兼容的问题 这是用dw做的框架 实际代码 var nums = [], timer, n = $$("idSlider2").getElementsByTagName("li").length, st = new SlideTrans("idContainer2", "idSlider2", n, { onStart: function(){//设置按钮样式 forEach(nums, f

去除链接元素的虚线框(兼容IE7、IE6、FF)

DIVCSS实例教程:去除链接元素的虚线框(兼容IE7.IE6.FF)-浏览器兼容教程 Web的发展非常迅速,UI设计也越来越美观,漂亮.同时也给WEB前端编码提出了新的要求.链接元素在点击时会出现虚线框,由于种种原因,您的主管可能要求你想办法将链接虚线边框出除. 我们采用htc文件的办法来解决这个问题.首页将以下代码保存为link.htc文件.   <public:attach event="onfocus" onevent="hscfsy()"/>

html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器

原文:html5 图片上传,支持图片预览.压缩.及进度显示,兼容IE6+及标准浏览器 以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上传组件添加了单独的图片上传UI,支持图片预览和缩放(通过调整图片的大小以实现图片压缩). 上传组件特点 轻量级,不依赖任何JS库,核心代码(Q.Uploader.js)仅约700行,min版本加起来不到12KB 纯

兼容ie8 ff ie6复制内容到剪切板

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-

百度浏览器兼容模式在哪设置 百度浏览器兼容模式设置教程

1.在电脑中打开"百度浏览器"之的我们会看到浏览器的地址栏处一个闪电的图标 如下图所示 2.然后我们点击闪电图标处,你会看到有一个"点击切换到兼容模式",点击一下小闪电. 3.现在我们点击 兼容模式,只要再点击一下,又会切换到极速模式. 友情提示,其实兼容模式小编觉得360浏览器做得更好了,它的可以兼容指定版本的浏览器了.

复制内容到剪切板( 兼容ie8 ff ie6)

  <!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.111cn.net/ 1999/xhtml"> <head> <meta http-equiv="co

一篇关于调优的概念性文章

今天看了一篇关于调优的概念性文章(61998.1: Introduction to Tuning Oracle7 / Oracle8 / 8i / 9i ). 文章的目的是为了可以快速知晓执行过程中哪里花费了较多的时间,而不是关注不同统计数据的含义.更加关注实际. 1. 为什么需要调优tuning?         通常我们关注的是用户响应时间或批量作业的处理时间.也许是某天当中若干时间点出现性能问题,或者性能问题一直如此.也许仅仅一些用户函数执行较差,或者所有的函数执行地都慢.大多数系统都是用

如何写好一篇符合用户体验的优质文章

网站优化看似容易但在操作上却有很多需要注意的细节,今天我为大家带来的是我在网站优化中的一个特长:写文章做优化.运营网站两年多时间了,我到现在仍然不知道黑链是如何利用的.站群如何构建,但是我手中的三个网站都有不错的排名与流量,因为我会写正规的网站优化文章,下面我来谈谈如何才能写出一篇正规的网站优化文章,欢迎大家拍砖. 优化文章的标题写作方法: 1.标题写作应该与所优化的关键词密切相连,假如你是做的一个"电动机"网站,那么你所写的文章标题就可以是与电动机有关的,比如说:分析什么样的电动机才

css 兼容-CSS兼容ie8,浏览器模式与文本模式

问题描述 CSS兼容ie8,浏览器模式与文本模式 目前在做公司网站,检验个浏览器的兼容性,其他都好,唯独ie8以及8以下都不行,但是咯啊办要求兼容ie8,但自己版本是10,在8版本下,样式完全乱了,有没有什么好的办法啊? 之前在360检验时,360有快速模式和兼容模式,在代码中使用了前者是默认使用360的快速模式,后者是默认使用ie9版本,但是在ie8上面时仍然无法正确排版.有木有什么好的解决方案啊? 另外,在ie中使用F12,可以改掉浏览器模式和文档模式,通过选择这两个可以使用不同的ie版本来