按下列步骤执行,可解决bootstrap在各版本IE浏览器中的兼容性问题:
- 有没有正确调用远程地址
即只要是IE9以下,就调用两个专门的js:
<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!--[if lt IE 9]>
<script src="<a%20href="http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js%22%3E%3C/script%3E" target="_blank" rel="nofollow">http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
<script src="<a%20href="http://apps.bdimg.com/libs/respond.js/1.4.2/respond.min.js%22%3E%3C/script%3E" rel="external nofollow" target="_blank" rel="nofollow">http://apps.bdimg.com/libs/respond.js/1.4.2/respond.min.js"></script>
<![endif]--> - 调用方法正不正确
不要用file://或@import形式引用respond.min.js或respond.js或css文件; - 针对浏览器的内容做标识(使用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>标签高人的英文解释可以参看
<a%20href="http://stackoverflow.com/questions/6771258/whats-the-difference-if-meta-http-equiv-x-ua-compatible-content-ie-edge-e" rel="external nofollow" target="_blank" rel="nofollow">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标签来告诉浏览器使用什么内核来渲染页面 - IE8不支持container的几个属性
IE8不完全支持box-sizing:border-box与min-width, max-width, min-height或max-height的一起使用.所以,v3.0.1的bootstrap中对container的类,已经不再使用max-width了。 - JS与CSS的引入顺序导致的问题
必须先引用css在引用js
<link rel="stylesheet" type="text/css" href="bootstrap.min.css" rel="external nofollow" media="screen"/>
<script type="text/javascript" src="js/respond.min.js"></script> - DOCTYPE前后有空行
<!DOCTYPE html>
这里有空格也不行,要去掉空格
<html> - 可以手动修改bootstrap.css
如果您使用的是bootstrap2.1.1,修改了navbar-inner{ filter:none}可解决问题,如果使用的是3.0+版的,没有这段代码了,详细介绍请看连接
<a%20href="http://stackoverflow.com/questions/12460190/bootstrap-navbar-does-not-show-in-ie8" rel="external nofollow" target="_blank" rel="nofollow">http://stackoverflow.com/questions/12460190/bootstrap-navbar-does-not-show-in-ie8 - 在IE11下测试通过,但是在IE8下测试,有发现一个问题placeholder不被支持
下面是解决IE支持placeholder的方法
本文引用的jquery是1.11.1测试通过,先引用jquery
<script type="text/javascript" src="<a%20href="http://code.jquery.com/jquery-1.11.1.min.js%22%3E%3C/script%3E" rel="external nofollow" target="_blank" rel="nofollow">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这个文件的下载地址<a%20href="https://github.com/mathiasbynens/jquery-placeholder" rel="external nofollow" target="_blank" rel="nofollow">https://github.com/mathiasbynens/jquery-placeholder
然后再文件中加入一下代码
<script type="text/javascript">
$(function () {
// Invoke the plugin
$('input, textarea').placeholder();
});
</script>