让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)


Posted in HTML / CSS onApril 08, 2014

如今HTML5愈来愈引发大家的关注了,但目前支持HTML5的浏览器还不是主流,特别是国内用户近50%以上仍旧使用IE6,由于支持HTML5的IE9不支持Xp系统安装,这样未来很长一段时间,HTML5的开发者将必须考虑向下兼容的问题。HTML5的标签或CSS选择器兼容性的做法有很多,其中自己生成标签元素就是一种。

基本原理参见如下代码在IE8中效果,样式根本没有起作用。

复制代码
代码如下:

<html>
<head>
<style>mxria{ color: red; }</style>
</head>
<body>
<mxria>Hello!</mxria>
</body>
</html>

让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)

为了是浏览器识别<mxria></mxria>标签并显示对应样式的效果,我们可以如下增加一段js,看到效果就不同了

复制代码
代码如下:

<html>
<head>
<style> mxria{ color: red; }</style>
<script>document.createElement("mxria")</script>
</head>
<body>
<mxria>Hello!mxria.com</mxria>
</body>
</html>

让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)

现在大家明白了其中的奥妙吧!对,就是document.createElement  ,HTML5 shiv就是这样一个js插件,将所有HTML5的标签进行了重新生成,你需要加载该插件,那么HTML5程序就能被所有浏览器识别了。
下载地址:http://html5shim.googlecode.com/svn/trunk/html5.js

trunk/html5.js简单使用方法:

下面是引用Google的html5.js文件:

html5shiv的使用非常的简单,考虑到IE9是支持html5的,所以只需要在页面head中添加如下代码即可:

复制代码
代码如下:

<!--[if lt IE 9]>
<script src="dist/html5shiv.js"></script>
<![endif]-->

将上代码复制到head部分,记住一定要是head部分(因为IE必须在元素解析前知道这个元素,所以这个js文件不能在其他位置调用,否则失效)

当然,你也可以把代码拿出来自己看着办:

(function(){if(!/*@cc_on!@*/0)return;var e ="abbr,article,aside,audio,canvas,datalist,details,dialog,eventsource,figure,footer,header,hgroup,mark,menu,meter,nav,output,progress,section,time,video".split(','),i=e.length;while(i--){document.createElement(e[i])}})()
最后在css里面加上这段:

/*html5*/ article,aside,dialog,footer,header,section,footer,nav,figure,menu{display:block}
主要是让这些html5标签成块状,像div那样。

好了,简单吧,一句话概括就是:引用html5.js  使html5标签成块状

HTML / CSS 相关文章推荐
CSS3旋转——彩色扇子兼容firefox浏览器
Jun 04 HTML / CSS
用css3实现当鼠标移进去时当前亮其他变灰效果
Apr 08 HTML / CSS
CSS3简单实现照片墙
Dec 12 HTML / CSS
CSS3实现滚动条动画效果代码分享
Aug 03 HTML / CSS
如何开发一款堪比APP的微信小程序(腾讯内部团队分享)
Dec 22 HTML / CSS
前端面试必备之html5的新特性
Sep 05 HTML / CSS
html5 兼容IE6结构的实现代码
May 14 HTML / CSS
HTML5图片预览实例分享
Jun 04 HTML / CSS
关于HTML5 Placeholder新标签低版本浏览器下不兼容的问题分析及解决办法
Jan 27 HTML / CSS
AmazeUI 输入框组的示例代码
Aug 14 HTML / CSS
amazeui模态框弹出后立马消失并刷新页面
Aug 19 HTML / CSS
html+css实现文字折叠特效实例
Jun 02 HTML / CSS
为你的html5网页添加音效示例
Apr 03 #HTML / CSS
使用jquery实现HTML5响应式导航菜单教程
Apr 02 #HTML / CSS
简单html5代码获取地理位置
Mar 31 #HTML / CSS
HTML5注册页面示例代码
Mar 27 #HTML / CSS
html5实现微信打飞机游戏
Mar 27 #HTML / CSS
html5 canvas fillRect坐标和大小的问题解决方法
Mar 26 #HTML / CSS
html5适合移动应用开发的12大特性
Mar 19 #HTML / CSS
You might like
一台收音机,让一家人都笑逐颜开!
2020/08/21 无线电
php5 图片验证码实现代码
2009/12/11 PHP
PHP图片等比例缩放生成缩略图函数分享
2014/06/10 PHP
PHP实现生成透明背景的PNG缩略图函数分享
2014/07/08 PHP
xheditor与validate插件冲突的解决方案
2010/04/15 Javascript
javascript 伪数组实现方法
2010/10/11 Javascript
浅析js中取绝对值的2种方法
2013/07/09 Javascript
javascript结合fileReader 实现上传图片
2015/01/30 Javascript
基于Jquery代码实现手风琴菜单
2015/11/19 Javascript
jQuery短信验证倒计时功能实现方法详解
2016/05/25 Javascript
jQuery插件imgAreaSelect基础讲解
2017/05/26 jQuery
vue.js框架实现表单排序和分页效果
2017/08/09 Javascript
微信小程序倒计时功能实现代码
2017/11/09 Javascript
深入浅析vue组件间事件传递
2017/12/29 Javascript
Vue匿名插槽与作用域插槽的合并和覆盖行为
2019/04/22 Javascript
js+css3实现简单时钟特效
2020/09/13 Javascript
原生js实现俄罗斯方块
2020/10/20 Javascript
[02:21]DOTA2英雄基础教程 蝙蝠骑士
2013/12/16 DOTA
[03:52]DOTA2英雄基础教程 酒仙
2013/12/23 DOTA
Python操作Mysql实例代码教程在线版(查询手册)
2013/02/18 Python
用Python中的字典来处理索引统计的方法
2015/05/05 Python
从源码解析Python的Flask框架中request对象的用法
2016/06/02 Python
python字符串和常用数据结构知识总结
2019/05/21 Python
pytorch 实现在预训练模型的 input上增减通道
2020/01/06 Python
python tkinter之 复选、文本、下拉的实现
2020/03/04 Python
Python logging模块原理解析及应用
2020/08/13 Python
荷兰牛仔裤网上商店:Jeans Centre
2018/04/03 全球购物
KENZO官网:高田贤三在法国创立的品牌
2019/05/16 全球购物
北大自主招生自荐信
2013/10/19 职场文书
趣味游戏活动方案
2014/02/07 职场文书
奥巴马英文演讲稿
2014/05/15 职场文书
采购部长岗位职责
2014/06/13 职场文书
教师正风肃纪心得体会
2016/01/15 职场文书
Go使用协程交替打印字符
2021/04/29 Golang
matlab xlabel位置的设置方式
2021/05/21 Python
MySQL 十大常用字符串函数详解
2021/06/30 MySQL