如何解决bootstrap与ie不兼容问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何解决bootstrap与ie不兼容问题相关的知识,希望对你有一定的参考价值。

参考技术A bootstrap有使用CSS3,所以ie9以下浏览器不会很顺畅。IE9以下的兼容性不是很好。
IE本身就是怪胎,就搞一些和外界标准不一致。搞得web开发考虑这考虑那的兼容性,蛋疼!

基本上css3的没法正常使用:

- 无法正常显示 CSS 3 圆角 -> 全部变成方块
- 无法正常显示 CSS 3 渐变 -> 拟物的按钮全都变成了扁平的
- 无法正常显示 CSS 3 阴影 -> 方块就是方块,没有影子

搜了下一些解决方案:
1. Bootstrap UI整体在IE8下变窄,进而组件摆放论套

问题出在IE8不支持@media ,而Bootstrap的一大优势Responsive UI是完全基于@media的。解决这个问题, 使用Respond.js

2. Bootstrap UI组件在IE8下美观有问题

使用bootstrap-ie78.css本回答被提问者和网友采纳
参考技术B 方法一:引用第三方js,一个叫respond.js的东西,github上可以搜到

方法二:由于IE8不支持媒体查询,所以对应不同分辨率的样式失效了,所以解决方法也很简单,都用col-xs的列布局来实现就好了。
参考技术C 需要确保你的html页面开始部分要有DOCTYPE声明。DOCTYPE告诉浏览器使用什么样的HTML或XHTML规范来解析HTML文档,具体会影响:
对标记attributes 、properties的约束规则
对浏览器的渲染模式产生影响,不同的渲染模式会影响到浏览器对于CSS代码甚至javascript脚本的解析
DOCTYPE是非常关键的,目前的最佳实践就是在HTML文档的首行键入:
<!DOCTYPE html>

怎么解决bootstrap在各版本IE浏览器中的兼容性问题???

用了bootstrap模版搭建的网站,在IE7中打不开,在IE8中背景图片都不显示,内容排列也出现问题,在IE9中表现的最好,在IE11中出现弹出层中的图片无法显示,请问这些兼容性怎么去解决????

Bootstrap的目标是在最新的桌面和移动浏览器上有最佳的表现,也就是说,在较老旧的浏览器上可能会导致某些组件表现出的样式有些不同,但是功能是完整的。
bootstrap3支持的浏览器:

Chrome (Mac、Windows、iOS和Android)
Safari (只支持Mac和iOS版,Windows版已经基本死掉了)
Firefox (Mac、Windows)
Internet Explorer
Opera (Mac、Windows)
Bootstrap在Chromium、Linux版Chrome、Linux版Firefox和Internet Explorer 7上的表现也是很不错的,只是官方并不提供支持。
Internet Explorer 8 和 9的很多CSS3属性和HTML5元素,例如圆角矩形和投影,不支持。
Internet Explorer 6 几乎不支持,nav, pagination 等在ie6上表现都特别差。
使用bootstrap2的bsie插件 http://www.bootcss.com/p/bsie/ ,提取插件里的 bootstrap-ie6.css 和ie.css,在页面的head里bootstrap.css之下加入如下代码:
<!--[if lte IE 6]>
<link rel="stylesheet" type="text/css" href="/css/bootstrap-ie6.css?1">
<![endif]-->
<!--[if lte IE 7]>
<link rel="stylesheet" type="text/css" href="/css/ie.css">
<![endif]-->
禁用响应式布局:

<link href="/css/non-responsive.css" rel="stylesheet" media="screen">

html里的css代码:

<style type="text/css">
body
padding-top: 60px;
padding-bottom: 40px;

/* 禁用响应式布局:重新设置container的宽度。如果没有后面三行的代码,在IE6环境下navbar-top会显示为940px宽度 */
.container,
.navbar-static-top .container,
.navbar-fixed-top .container,
.navbar-fixed-bottom .container
width:1140px;

</style>

打开 bootstrap-ie6.css文件,将文件里的pager替换为pagination,用于支持bootstrap3的分页组件。并在底部加入如下代码,代码作用请看注释:

/* 栅栏系统,溢出的问题 */
.col-xs-1
width: 5.7%;

.col-xs-2
width: 13.96%;

.col-xs-3
width: 22.2%;

.col-xs-4
width: 30.5%;

.col-xs-5
width: 38.8%;

.col-xs-6
width: 47%;

.col-xs-7
width: 55.2%;

.col-xs-8
width: 63.5%;

.col-xs-9
width: 72%;

.col-xs-10
width: 80%;

.col-xs-11
width: 88.3%;

.col-xs-12
width: 100%;


/* 修复ie6下分页组件css解析失败的问题 */
.pagination .active a,
.pagination .active span
z-index: 2;
color: #ffffff;
cursor: default;
background-color: #428bca;
border-color: #428bca;


/* 修复ie6下input样式被重写的问题*/
.form-control
display: block;
width: 100%;
height: 34px;
padding: 6px 12px;
font-size: 14px;
line-height: 1.428571429;
color: #555555;
vertical-align: middle;
background-color: #ffffff;
border: 1px solid #cccccc;
border-radius: 4px;

在html页body之上添加如下代码:

<!--[if lte IE 6]>
<script type="text/javascript" src="/js/bootstrap-ie.js"></script>
<![endif]-->
<script type="text/javascript">
(function ($)
$(document).ready(function()
if ($.isFunction($.bootstrapIE6)) $.bootstrapIE6($(document));
);
)(jQuery);
</script>

html整个头部文件如下:

<!DOCTYPE HTML>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
<!-- Bootstrap theme -->
<link href="/css/bootstrap-theme.min.css" rel="stylesheet">
<!--[if lte IE 6]>
<link rel="stylesheet" type="text/css" href="/css/bootstrap-ie6.css?1">
<![endif]-->
<!--[if lte IE 7]>
<link rel="stylesheet" type="text/css" href="/css/ie.css">
<![endif]-->
<link href="/css/non-responsive.css" rel="stylesheet" media="screen">
<link href="/css/showLoading.css" rel="stylesheet" media="screen">
<script type="text/javascript" src="/js/jquery-1.10.2.min.js"></script>
<script type="text/javascript" src="/js/bootstrap.min.js"></script>
<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
<!--[if lt IE 9]>
<script src="/js/html5shiv.js"></script>
<script src="/js/respond.min.js"></script>
<![endif]-->
<style type="text/css">
body
padding-top: 60px;
padding-bottom: 40px;

/* 禁用响应式布局:重新设置container的宽度。如果没有后面三行的代码,在IE6环境下navbar-top会显示为940px宽度 */
.container,
.navbar-static-top .container,
.navbar-fixed-top .container,
.navbar-fixed-bottom .container
width:1140px;

</style>
参考技术A

按下列步骤执行,可解决bootstrap在各版本IE浏览器中的兼容性问题:

    有没有正确调用远程地址
    即只要是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]-->

    调用方法正不正确
    不要用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>标签高人的英文解释可以参看
    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" 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+版的,没有这段代码了,详细介绍请看连接
    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="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>

以上是关于如何解决bootstrap与ie不兼容问题的主要内容,如果未能解决你的问题,请参考以下文章

怎么解决bootstrap在各版本IE浏览器中的兼容性问题???

如何解决 IE下 上传文件的兼容性问题

bootstrap4支持IE9+浏览器吗

JS组件系列——Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案

bootstrap与360浏览器兼容问题

IE兼容性问题