讓IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解決方法
首先需要確保你的HTML頁面開始部分要有DOCTYPE聲明。DOCTYPE告訴瀏覽器使用什么樣的HTML或XHTML規范來解析HTML文檔,具體會影響:
對標記attributes 、properties的約束規則
對瀏覽器的渲染模式產生影響,不同的渲染模式會影響到瀏覽器對于CSS代碼甚至JavaScript腳本的解析
DOCTYPE是非常關鍵的,目前的最佳實踐就是在HTML文檔的首行鍵入:
<!DOCTYPE html>
Bootstrap3 是移動設備優先的原則開發的,所以原因可能如下:
1.沒有正確調用遠程地址
即只要是IE9以下,就調用兩個專門的js
1 <!--[if lt IE 9]> 2 <script src="http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script> 3 <script src="http://apps.bdimg.com/libs/respond.js/1.4.2/respond.min.js"></script> 4 <![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標簽,因為目前國內的主流瀏覽器都是雙內核,故而添加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.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>
然后再文件中加入一下代碼
1 <script type="text/javascript"> 2 $(function () { 3 // Invoke the plugin 4 $('input, textarea').placeholder(); 5 }); 6 </script>