`

让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法

 
阅读更多

本文转自:

http://www.ijophy.com/2014/05/bootstrap3-compatible-with-ie8.html

 

最 近做一个Web网站,之前一直觉得bootstrap非常好,这次使用了bootstrap3,在 chrome,firefox,safari,opera,360浏览器(极速模式)、搜狗浏览器等浏览器下均没有问题,而在IE8及IE11下发现样式 无法显示,然后各种百度啊,最后在 雅朋网 的一个网友帖子的帮助下解决了问题,也参考了 千寻学习网 的资料,先将解决方法总结如下:


首先需要确保你的HTML页面开始部分要有DOCTYPE声明。DOCTYPE告诉浏览器使用什么样的HTML或XHTML规范来解析HTML文档,具体会影响:
对标记attributes 、properties的约束规则
对浏览器的渲染模式产生影响,不同的渲染模式会影响到浏览器对于CSS代码甚至JavaScript脚本的解析
DOCTYPE是非常关键的,目前的最佳实践就是在HTML文档的首行键入:
<!DOCTYPE html>


大神的帖子总结的bootstrap的查找原因好几条,首先,Bootstrap3 是移动设备优先的原则开发的,所以原因可能如下:
1.没有正确调用远程地址
即只要是IE9以下,就调用两个专门的js
<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!--[if lt IE 9]>
  <script src="http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
  <script src="http://apps.bdimg.com/libs/respond.js/1.4.2/respond.min.js"></script>
<![endif]-->
但是我测试发现仅仅使用以上js文件不可行,
2.调用方法不正确
不要用file://或@import形式引用respond.min.js或respond.js或css文件


3.针对浏览器的内容做标识(使用meta标签调节浏览器的渲染方式)
bootstrap不支持IE兼容模式,为了让IE浏览器运行最新的渲染模式,将添加以下标签在页面中
<meta http-equiv="X-UA-Compatible" content="IE=edge,Chrome=1" />
IE=edge表示强制使用IE最新内核,chrome=1表示如果安装了针对IE6/7/8等版本的浏览器插件Google Chrome Frame(可以让用户的浏览器外观依然是IE的菜单和界面,但用户在浏览网页时,实际上使用的是Chrome浏览器内核),那么就用Chrome内核来 渲染。关于此meta标签的具体说明,可参见StackOverflow上的精彩回答,<meta>标签高人的英文解释可以参看
http://stackoverflow.com/questions/6771258/whats-the-difference-if-meta-http-equiv-x-ua-compatible-content-ie-edge-e
我有加了一句
<meta http-equiv="X-UA-Compatible" content="IE=9" />
然后就可以了
内核控制Meta标签,因为目前国内的主流浏览器都是双内核,故而添加meta标签来告诉浏览器使用什么内核来渲染页面


4.IE8不支持container的几个属性
IE8不完全支持box-sizing:border-box与min-width, max-width, min-height或max-height的一起使用.所以,v3.0.1的bootstrap中对container的类,已经不再使用max- width了。


5.JS与CSS的引入顺序导致的问题
必须先引用css在引用js
<link rel="stylesheet" type="text/css" href="bootstrap.min.css" media="screen"/>
<script type="text/javascript" src="js/respond.min.js"></script>


6.DOCTYPE前后有空行
<!DOCTYPE html>
这里有空格也不行,要去掉空格
<html>


7.也可以手动修改bootstrap.css
如果您使用的是bootstrap2.1.1,修改了navbar-inner{ filter:none}可解决问题,如果使用的是3.0+版的,没有这段代码了,详细介绍请看连接
http://stackoverflow.com/questions/12460190/bootstrap-navbar-does-not-show-in-ie8


8.使用quirks mode(兼容模式)
定义网页时,向后兼容旧的浏览器的模式就是quirks mode,与之对应的是“标准模式”就是 standard mode。具体是将<!DOCTYPE html>写成以前的这种
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
这个我测试过,不可行


最后我在IE11下测试通过,但是在IE8下测试,有发现一个问题placeholder不被支持
下面是解决IE支持placeholder的方法
本文引用的jquery是1.11.1测试通过,先引用jquery
<script type="text/javascript" src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
也可以用其他的jquery版本
再引入<script type="text/javascript" src="js/jquery.placeholder.js"></script>
jquery.placeholder.js这个文件的下载地址https://github.com/mathiasbynens/jquery-placeholder
然后再文件中加入一下代码
<script type="text/javascript">
    $(function () {
        // Invoke the plugin
        $('input, textarea').placeholder();
    });
</script>
如果我这里为涉及到的或者问题依然没有解决的请移步http://hustlzp.com/post/2014/01/ie8-compatibility更加详细


以上IE6,7,8,9,10,11,chrome,firefox,safari,opera,360浏览器(极速模式)、搜狗浏览器测试通过,只有IE5.5似乎不太可行,总之问题解决到此,万恶的IE6-都叫它打酱油去吧


如果您不想使用jquery.placeholder.js,再不支持placeholder的浏览器下模拟placeholder实现
可参考此文讲很详细http://ju.outofmemory.cn/entry/1595

 

分享到:
评论

相关推荐

    bootstrap3 支持ie8

    6. **用户教育**:在项目中明确指出不支持IE8,鼓励用户升级浏览器或使用现代浏览器,这是一个更长远的解决方案,但可能不适用于所有情况。 综上所述,使Bootstrap3在IE8下运行是一项挑战,需要对CSS和JavaScript有...

    bootstrap-ie8_ie9.rar

    为了使Bootstrap在IE8和IE9上正常运行,你需要按照以下步骤操作: 1. 在页面头部引入HTML5shiv和Respond.js,确保它们在所有其他CSS和JS之前加载。 ```html &lt;!--[if lt IE 9]&gt; ...

    bootstrap-ie8.rar

    2. **Flexbox不支持**:Bootstrap4及以上版本使用Flexbox进行栅格布局,而IE8不支持Flexbox,需要降级处理,使用传统的浮动或display: table-cell等方法。 3. **JavaScript问题**:Bootstrap的一些组件,如下拉菜单...

    解决bootstrap 3 IE8兼容性问题

    解决bootstrap 3 IE8兼容性问题 研究了下getbootstrap.com网站在IE8下是正常的,他们采取的解决办法是: &lt;!--[if lt IE 9]&gt;&lt;script src="../assets/js/ie8-responsive-file-warning.js"&gt;&lt;/script&gt;&lt;![endif]--&gt; &lt;!--...

    bootstrap兼容IE6的css

    然而,Bootstrap默认并不支持较老的浏览器,尤其是Internet Explorer (IE) 的早期版本,如IE6、IE7。标题“bootstrap兼容IE6的css”表明我们要解决的是使Bootstrap在这些老版本的IE浏览器中正常工作的技术问题。 在...

    ie8缓存+bootstrap结合ie8的jquery版本

    1.解决ie8缓存 2.bootstrap结合ie8的jquery版本 3.ie8不支持bootstrap的部分功能

    Bootstrap后台管理模板支持IE8以上

    "Bootstrap后台管理模板支持IE8以上"意味着这个模板是专为那些还需要兼容Internet Explorer 8及更高版本的开发者设计的。在当前Web开发环境中,虽然许多现代浏览器已经不再支持IE8,但考虑到一些企业的遗留系统或...

    让bootstrap兼容IE8的respond.js

    然而,Bootstrap默认并不支持较老的浏览器,尤其是Internet Explorer 8(IE8)及以下版本,因为它们不支持媒体查询(Media Queries),这是实现响应式设计的关键部分。`respond.js`是一个轻量级的JavaScript库,由...

    基于bootstrap兼容ie7+后台模板

    在实现对IE7+的兼容时,开发者可能需要利用特定的CSS hack或者JavaScript库,如jQuery,因为Bootstrap本身只支持IE9及以上版本。例如,使用条件注释、*前缀属性或者expression()表达式来解决IE7特有的样式问题。同时...

    bootstrap-ie11:用于Bootstrap 5的Internet Explorer 11兼容性解决方案

    "bootstrap-ie11"项目就是为了解决这个问题而诞生的,它旨在为Bootstrap 5提供IE11的兼容性支持。 首先,我们需要理解Bootstrap 5放弃IE11支持的原因。主要在于IE11对现代Web标准的不完全支持,如CSS Flexbox、Grid...

    bootstrap-ie6补丁

    “bootstrap-ie6补丁”是为了使Bootstrap能够在Internet Explorer 6上正常运行而设计的一套解决方案。它通常包括对原始Bootstrap CSS和JavaScript的修改,以及可能的polyfill(一种模拟新功能的旧浏览器代码)来弥补...

    bootstrap-ie练习

    在处理与Internet Explorer(尤其是较旧版本如IE6、IE7和IE8)的兼容性问题时,Bootstrap可能会遇到一些挑战,因为这些老版本的浏览器对现代Web标准的支持有限。 "bootstrap-ie练习"这个项目显然旨在解决Bootstrap...

    bootstarp 3.0兼容ie7

    6. **PNG透明度支持**: IE7对PNG透明度的支持有限,可能需要使用AlphaImageLoader滤镜或其他方法来修复。 7. **DOCTYPE声明**: 使用正确的DOCTYPE声明,如`&lt;!DOCTYPE html&gt;`,可以确保IE7进入标准模式,避免怪异...

    bootstrop兼容IE8的代码

    6. **禁用某些组件**:某些Bootstrap组件在IE8下可能无法正常工作,例如Glyphicons图标字体,因为IE8不支持@font-face。在这种情况下,可能需要寻找替代方案或者禁用这些组件。 7. **优化JavaScript**:Bootstrap的...

    Bootstrap-datetimepicker先天bug修复,兼容IE6+

    4. **事件处理**:IE6-8不支持addEventListener和removeEventListener,需要使用attachEvent和detachEvent替代。同时,事件冒泡和捕获机制在IE中与其他浏览器有所不同,需注意处理。 5. **盒模型**:IE6默认使用...

    bootstrap-ie7:IE7的Bootstrap 3 CSS

    1. 不支持浮动元素的高度塌陷(clearfix)解决方案,`bootstrap-ie7`可能包含了专门的类来处理这个问题。 2. 不支持CSS3选择器,如`:hover`, `:first-child`等,需要通过JavaScript或者额外的类来实现类似效果。 3. ...

    解决SHOPEX不兼容IE9、IE10

    标题中的“解决SHOPEX不兼容IE9、IE10”表明了本文将探讨一个针对电子商务平台SHOPEX的兼容性问题,主要聚焦在它无法正常运行于Internet Explorer (IE) 9和10这两个版本上。SHOPEX是一款基于PHP的开源电子商务系统,...

    IE6 -- IE8浏览器CSS兼容性查询手册【gif格式】

    9. Flexbox和Grid布局:这些现代布局技术在IE6-8中完全不被支持,需要依赖于传统布局方法或者使用JavaScript库。 通过这个“IE6 -- IE8浏览器CSS兼容性查询手册”,开发者可以快速查找和解决在这些旧版IE浏览器中...

    AngularJs兼容IE6-IE7-IE8

    项目需要、在网上查找angularjs支持ie低版本的问题(主要是windows7下只有IE8)整理了一个小demo 主要两点 1、ng-app="myApp" id="test11" 加上id="XXX" 加入以下代码注册到页面上 angular.element(document)....

    UI框架模板一(兼容IE8)

    在"UI框架模板一(兼容IE8)"中,这个系统被优化以适应IE8的CSS2.1规范,因为IE8并不支持CSS3的某些特性,如媒体查询。因此,开发者可能使用了条件注释、HTML5shiv等技术来弥补IE8的不足。 此外,Bootstrap还提供了一...

Global site tag (gtag.js) - Google Analytics