全系IE支持Bootstrap的解决方法


Posted in Javascript onOctober 19, 2015

最近做一个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>

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

Javascript 相关文章推荐
基于jquery扩展漂亮的下拉框可以二次修改
Nov 19 Javascript
node.js入门教程迷你书、node.js入门web应用开发完全示例
Apr 06 Javascript
node.js中的fs.renameSync方法使用说明
Dec 16 Javascript
Canvas实现放射线动画效果
Feb 15 Javascript
JS去掉字符串前后空格、阻止表单提交的实现代码
Jun 08 Javascript
使用Bootrap和Vue实现仿百度搜索功能
Oct 26 Javascript
详解node child_process模块学习笔记
Jan 24 Javascript
React Native中NavigatorIOS组件的简单使用详解
Jan 27 Javascript
vue前端框架—Mint UI详解(更适用于移动端)
Apr 30 Javascript
JavaScript强制类型转换和隐式类型转换操作示例
May 01 Javascript
Vue-CLI项目中路由传参的方式详解
Sep 01 Javascript
微信小程序实现签字功能
Dec 23 Javascript
JS+CSS实现分类动态选择及移动功能效果代码
Oct 19 #Javascript
谈谈Jquery中的children find 的区别有哪些
Oct 19 #Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
Oct 19 #Javascript
JS实现的左侧竖向滑动菜单效果代码
Oct 19 #Javascript
jQuery实现ctrl+enter(回车)提交表单
Oct 19 #Javascript
JS实现网页游戏中滑块响应鼠标点击移动效果
Oct 19 #Javascript
在JavaScript中如何解决用execCommand(
Oct 19 #Javascript
You might like
javascript显示隐藏层比较不错的方法分析
2008/09/30 Javascript
JS定时刷新页面及跳转页面的方法
2013/07/04 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
js和jquery中循环的退出和继续下一个循环
2014/09/03 Javascript
javascript的BOM
2016/05/03 Javascript
JS求解三元一次方程组值的方法
2017/01/03 Javascript
js实现倒计时效果(小于10补零)
2017/03/08 Javascript
jQuery使用eraser.js插件实现擦除、刮刮卡效果的方法【附eraser.js下载】
2017/04/28 jQuery
详解VUE中v-bind的基本用法
2017/07/13 Javascript
Vue修改mint-ui默认样式的方法
2018/02/03 Javascript
layer弹出层父子页面事件相互调用方法
2018/08/17 Javascript
详解vue-router导航守卫
2019/01/19 Javascript
JS使用H5实现图片预览功能
2019/09/30 Javascript
JQuery发送ajax请求时中文乱码问题解决
2019/11/14 jQuery
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
[48:21]Mski vs VGJ.S Supermajor小组赛C组 BO3 第一场 6.3
2018/06/04 DOTA
python批量导出导入MySQL用户的方法
2013/11/15 Python
快速查询Python文档方法分享
2017/12/27 Python
Selenium元素的常用操作方法分析
2018/08/10 Python
Pyqt5 实现跳转界面并关闭当前界面的方法
2019/06/19 Python
使用 python pyautogui实现鼠标键盘控制功能
2019/08/04 Python
Python字节单位转换实例
2019/12/05 Python
python 判断txt每行内容中是否包含子串并重新写入保存的实例
2020/03/12 Python
python 基于UDP协议套接字通信的实现
2021/01/22 Python
CSS3中的opacity属性使用教程
2015/08/19 HTML / CSS
AC Lens:购买隐形眼镜
2017/02/26 全球购物
欧洲最大的球衣网上商店:Kitbag
2017/11/11 全球购物
无畏的旅行:Intrepid Travel
2017/12/20 全球购物
奥地利时尚、美容、玩具和家居之家:Kastner & Öhler
2020/04/26 全球购物
电子信息科学专业自荐信
2014/01/30 职场文书
高考标语大全
2014/06/05 职场文书
2014年医院工作总结
2014/11/20 职场文书
物业保洁员岗位职责
2015/02/13 职场文书
中小学生安全教育观后感
2015/06/17 职场文书
《打电话》教学反思
2016/02/22 职场文书
background-position百分比原理详解
2021/05/08 HTML / CSS