讓IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解決方法

Bootstrap兼容IE系列的方法,其實最簡單就是從bootstrap 組件頁面複製html源代碼,而後再改爲本身的。
下面的文章中詳細介紹了處理方案,直接參照改,更快~
javascript

 

摘自 http://blog.csdn.net/chenhongwu666/article/details/41513901 css

最近作一個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>
若是我這裏爲涉及到的或者問題依然沒有解決的請移步http://hustlzp.com/post/2014/01/ie8-compatibility更加詳細


以上IE6,7,8,9,10,11,chrome,firefox,safari,opera,360瀏覽器(極速模式)、搜狗瀏覽器測試經過,只有IE5.5彷佛不太可行,總之問題解決到此,萬惡的IE6-都叫它打醬油去吧


若是您不想使用jquery.placeholder.js,再不支持placeholder的瀏覽器下模擬placeholder實現
可參考此文講很詳細http://ju.outofmemory.cn/entry/1595html

相關文章
相關標籤/搜索