如何在IE中使用HTML 5元素

开发 前端
在HTML 5还未正式投入使用,在大多数浏览器中还是未知元素的这个时候,有一个简单的方法可以在IE中使用HTML 5元素。那就是,使用JS创建未知元素。

Sjoerd Visscher 发现了一个简洁的方法让样式在 IE 中作用到未知的元素上——仅需 JS 创建此未知元素即可:

  1. document.createElement(elementName) 

同理(对于 IE 来说 HTML 5元素即是未知元素),该方法也可顺延到 HTML 5 的元素上(详细见:John Resig 写的 《HTML5 Shiv》 一文):

  1. < html> 
  2. < head> 
  3. < style>section { color: red; }< /style> 
  4. < script>document.createElement("section")< /script> 
  5. < /head> 
  6. < body> 
  7. < section>Hello World!< /section> 
  8. < /body> 
  9. < /html> 

在 IE 中,为了更方便使用 HTML 5元素,我们可以引入这样的脚本:

  1. (function(){  
  2.     // from: http://dean.edwards.name/weblog/2007/03/sniff/  
  3.     if(!/*@cc_on!@*/0) return;   
  4.     var html5 = "abbr,article,aside,audio,bb,canvas,datagrid,datalist,details,dialog,  
  5. eventsource,figure,footer,hgroup,header,mark,menu,meter,nav,output,  
  6. progress,section,time,video".split(',');  
  7.     for(var i = 0, len = html5.length; i <  len; i++ )  
  8.         document.createElement(html5[i]);  
  9.     }  
  10. })(); 

详细具体应用的案例如下:

Moving markup towards HTML5

Test new HTML 5 elements

原文:http://www.planabc.net/2009/06/13/how_to_use_html5_elements_in_ie/

【编辑推荐】

  1. 关于HTML 5现状与未来的观点碰撞
  2. HTML 5中的五个应用亮点
  3. 细谈HTML 5新增的元素
  4. HTML 5倍受青睐,XHTML 2处境尴尬
  5. HTML 5 下一代Web开发标准详解
责任编辑:yangsai 来源: 51CTO论坛
相关推荐

2011-12-27 15:29:53

HTML 5

2010-06-17 11:38:57

2012-03-07 09:08:00

HTML 5

2011-05-12 09:01:29

HTML5

2021-03-09 07:27:40

Kafka开源分布式

2015-08-27 09:46:09

swiftAFNetworkin

2022-05-17 08:25:10

TypeScript接口前端

2024-01-18 08:37:33

socketasyncio线程

2021-06-09 09:36:18

DjangoElasticSearLinux

2022-06-23 08:00:53

PythonDateTime模块

2011-08-10 09:31:41

Hibernateunion

2019-09-16 19:00:48

Linux变量

2020-11-30 11:55:07

Docker命令Linux

2020-04-09 10:18:51

Bash循环Linux

2014-07-02 09:47:06

SwiftCocoaPods

2010-07-27 09:44:16

HTML 5

2023-12-01 09:18:27

AxiosAxios 库

2015-11-26 10:57:56

DockerOpen vSwitc

2021-09-10 10:30:22

Java代码

2022-10-25 09:07:28

Linuxxargs命令
点赞
收藏

51CTO技术栈公众号