这篇文章发布于 2012年07月20日,星期五,13:44,归类于 CSS相关。 阅读 94909 次, 今日 1 次 30 条评论
by zhangxinxu from http://www.zhangxinxu.com
本文地址:http://www.zhangxinxu.com/wordpress/?p=2515
如果我们不做什么手脚的话,IE6~IE8浏览器不支持HTML5元素, <nav>, <header>, <footer>, <article> …
然而,前篇Google前端规范HTML部分中提到:要使用语义的HTML5元素作为text/html, 考虑到Google不可能把IE8等浏览器弃之不顾,因此,肯定是有什么方法可以让IE6~8浏览器也支持HTML5元素的。
熟知的JavaScript方法
如果你对HTML5元素的关注比对红番茄八卦的关注多的话,应该都知道如何是有简单的JavaScript代码让IE6~8浏览器支持HTML5元素,类似下面代码:
(function() { // 页面头部 var a = ['section', 'article', 'nav', 'header', 'footer' /* 其他HTML5元素 */]; for (var i = 0, j = a.length; i < j; i++) { document.createElement(a[i]); } })();
您可以狠狠地点击这里:JS让IE支持HTML5元素demo
对比demo页面源代码以及实际效果,我们可以发现,简单的一句:
document.createElement("section");
就让section{}
的相关样式在IE7浏览器下生效了!!
提到使用JavaScript, 必定又有一些人拿可用性来叫嚣了:“尼玛,要是用户把JavaScript给禁掉,那不就嗝屁啦!”
据说因为twitter在JS被禁用的情况下就像中了葵花点穴手——动不了了!而被一些热心人士提意见:应该改进改进啊,可以让在JS禁用的情况下正常使用。
理想是丰满的,实现是荆棘的!讨论要不要在实际项目中支持无JavaScript的正常使用,会让刘先生发话的:“我活了42年,这是我见过的最无聊的问题!”
However, 就像是我们不会亲自实践人工呼吸,但是知道该怎么做还是有必要的。因此,我们知道如何不使用JavaScript让IE浏览器支持HTML5元素也是很有必要的。
*通配符方法
据说是WHATWG组提出的一个方法,如下建议:
- 知道DOM的体重以及三围,样式应用在其他元素上(非HTML元素)
- 使用全局选择器,通配符(
*
)指向正确的目标元素 - 无脚本应用
不过,根据我自己的尝试,这个方法让我感到有些莫名其妙:如果样式要应用在内部的其他元素上,尼玛直接在里面元素设置个类名控制不久OK了!!
可能,这种方法适用于类似于:
section p {}
这种含有HTML标记的后代选择器。上面的CSS选择器IE6~8是不认识的,WHATWG说的方法是使用:
body > * p {}
对IE7, IE8浏览器进行匹配(IE6不支持,我擦~~, 但这个FireFox , Chrome又都支持)
总之这是一个我看不懂,且觉得很蛋疼的不适应中国国情的方法,求高人指点!
您有兴趣可以狠狠地点击这里:*通配符让IE支持HTML5元素demo
为了避免各个浏览器间复杂的多角恋,我不得已使用了条件注释:
<!--[if lt IE 9]> <style> body > * .section { display: block; padding: .5em; border-left: 3px solid #ddd; color: #999; } </style> <![endif]--> <style> section .section { display: block; padding: .5em; border-left: 3px solid #ddd; color: #999; } </style>
HTML如下:
<section><div class="section">中国将向非洲...</div></section>
IE6下无效果,IE7下长相如下:
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]-->
这明眼人一眼就看出意思:IE6~8使用传统的<div>
标签,您对效果有兴趣的话,可以狠狠地点击这里:条件注释让IE支持HTML5元素demo
靠谱方法:使用命名空间
我们需要做的如下:
- 修改
<html>
标签处的命名空间 - 使用类似
<html5:section><html5:/section>
标签 - 使用如下选择器名称进行控制:
html5\:section {}
具体操作如下:
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:html5="http://www.w3.org/1999/xhtml">
<body>
<html5:section>...</html5:section>
</body>
</html>
然后使用:
html5\:section {
/* 样式 */
}
您可以狠狠地点击这里:命名空间让IE支持HTML5元素demo
上demo HTML代码为:
<div class="section">所有浏览器:黄忠,绿忠,黑忠,红中</div> <section>不包括IE6-8: 黄忠,绿忠,黑忠,红中</section> <html5:section>包括IE6-8浏览器:黄忠,绿忠,黑忠,红中<html5:/section>
CSS代码为:
.section, section, html5\:section { display: block; padding: .5em; border-left: 3px solid #ddd; color: #999; }
此时,我们在看看IE7浏览器下的效果:
该方法,IE6浏览器也是支持的。看上去使用也蛮清爽的。至少比上面两个方法要靠谱N倍了!
使用的时候注意XHTML需要没有错误,否则站点可能什么都显示不出来。同时,最头部可能要添加<?xml version="1.0" encoding="utf-8"?>
,据说,否则IE6会采用严格模式。
参考文章:HTML5 elements in Internet Explorer without Javascript
本文为原创文章,转载请注明来自张鑫旭-鑫空间-鑫生活[http://www.zhangxinxu.com]
本文地址:http://www.zhangxinxu.com/wordpress/?p=2515
(本篇完)
- HTML CSS列表元素ul,ol,dl的研究与应用 (0.845)
- 翻译 - 逐渐消失的Flash网站 (0.786)
- 翻译-你必须知道的28个HTML5特征、窍门和技术 (0.786)
- 关于Google圆角高光高宽自适应按钮及其拓展 (0.692)
- 告别图片—使用字符实现兼容性的圆角尖角效果beta版 (0.692)
- jQuery - 高亮动态显示页面HTML代码插件 (0.692)
- JavaScript实现新浪微博文字放大显示动画效果 (0.637)
- checkbox复选框的一些深入研究与理解 (0.633)
- 新浪微博插入话题后部分文字选中的js实现 (0.633)
- 翻译 - 解释JavaScript的“预解析(置顶解析)” (0.633)
- 给IE/Edge写了个textarea resize拉伸的polyfill (RANDOM - 0.155)
记得在降级的IE控制台上有类似这样的:
What Happened?
黄忠被玩坏了
很好的技巧,感谢博主分享!
额,还是这样= =!不能说样式冲突,是样式结合在一起了,互相有影响,~~~~(>_<)~~~~ 贴不了html代码。。。。。
好像我写两个的话,会有样式冲突~~~~(>_<)~~~~
无标题文档
html5\:header { background-color: #333; border: 1px solid #f00; color: #FFF;display: block; }
.section, section, html5\:section {
display: block;
padding: .5em;
border-left: 3px solid #ddd;
color: #999;
}
2233333
所有浏览器:黄忠,绿忠,黑忠,红中
不包括IE6-8: 黄忠,绿忠,黑忠,红中
包括IE6-8浏览器:黄忠,绿忠,黑忠,红中
我觉得吧,禁用js的操作的毕竟非常罕见,twitter在JS禁止的情况下动不了,就会google一下发生了什么?然后被告知是JS被禁用的问题,重新打开JS,这样会提高民众的WEB意识。或许直接弹出一个对话框说你的浏览器JS被禁用,点击一键打开,就噢了,没必要为这些1%的时间去花时间兼容
例如:UL中的 《ul contentEditable=”true”》
@卡卡西 这个IE本来就支持的吧~~
html5标签里的属性怎么解决?
最后一个在IE下还是没有起到作用呀
为什么要搞html5?个人看法,除了一系列规范和增加强大的canvas功能外,还有seo,“”这样的写法对seo会不会造成不良影响?~
额 又不行。。。
<!--[if gte IE 9]><!-->
Lorem ipsum dolor sit amet.
<!--<![endif]-->
这下呢。。。
好吧不知道这里的评论有这么纠结的规则。。。
老老实实转义字符吧
<!–[if gte IE 9]><!–>
Lorem ipsum dolor sit amet.
<!–<![endif]–>
这样研究意义不大,增加不必要的东东~还是用比较标准的html5,毕竟我们的向前看~
使用了命名空间的模式是不是就可以自己定义标签了啊?
还是等IE6彻底从天朝消失吧
你最后一个还是在IE下面有问题啊啊啊啊啊啊,你可以在看看
将IE6从地球上消灭!
张先生的方法果然凶残。那么还有木有不用高科技让IE6支持CSS3的方法呢?
你好,关注你的站很长一段时间了,学到不少东西。
有个问题请教:
src= 跟 href= 的区别是什么啊
网上有人说src是search的简写 ,也有人说是source的缩写,源的意思。
那么为何在链接外部css文件时用href,而链接js文件时用 src 呢 ?
自定义样式啊–!
大于小于号被弄没了,自己转义一下
果然蛋疼,实例了一下,虽然IE6~8可以用,但实际用的时候还是有问题的,比如:
<html5:section>
test
<html5:/section>
6~8中会在test后面产生空白字符。
蛋疼
设计交流123: QQ群:89474889
用ie6-8的会知道怎么禁用javascript吗?
还是国外技术发达,他们到底怎么想的这些问题的解决方法。
长见识了,一直都在用淘宝的html5.js。。嘿嘿
阳台上的西红柿活了N年,也不懂程序的美,自然觉得精益求精是件无聊的事。相恋3年的红番茄在记者招待会上捂着耳朵也听得到,你的博客更要刷新学习哈。
确实有点蛋疼。
张先生真无聊