bootstrap 不支持ie怎么办

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

bootstrap 不支持ie怎么办

bootstrap不支持ie的解决办法:首先确保HTML页面开始部分要有DOCTYPE声明;然后正确调用远程地址,并针对浏览器的内容做标识;最后检查并修改相应的js或css文件即可。

本文操作环境:Windows7系统、bootstrap3、Dell G3电脑。

bootstrap对IE9以下的浏览器存在一定的兼容问题,要解决这个兼容问题,必须引入相关的js文件进行相应的处理才能解决。下面本篇文章给大家介绍一下bootstrap不支持ie的解决方法,希望对大家有所帮助。

首先需要确保你的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文件不可行,

推荐:《bootstrap教程》

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版本

再引入

<!-- 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]-->0
登录后复制

jquery.placeholder.js这个文件的下载地址https://github.com/mathiasbynens/jquery-placeholder

然后再文件中加入一下代码

<!-- 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]-->1
登录后复制

如果我这里为涉及到的或者问题依然没有解决的请移步http://hustlzp.com/post/2014/01/ie8-compatibility更加详细

以上就是bootstrap 不支持ie怎么办的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:Bootstrap中怎么使用模态框?Modal组件用法浅析
下一篇:原来利用纯CSS也能实现拼图游戏!

发表评论

关闭广告
关闭广告