首頁  >  文章  >  web前端  >  bootstrap 不支援ie怎麼辦

bootstrap 不支援ie怎麼辦

藏色散人
藏色散人原創
2021-02-05 09:12:302710瀏覽

bootstrap不支援ie的解決方法:首先確保HTML頁面開始部分要有DOCTYPE聲明;然後正確調用遠端位址,並針對瀏覽器的內容做標識;最後檢查並修改對應的js或css文件即可。

bootstrap 不支援ie怎麼辦

本文操作環境: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上的精彩回答,e8e496c15ba93d81f6ea4fe5f55a2244標籤高人的英文解釋可以參考

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>
这里有空格也不行,要去掉空格

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。具體是將8b05045a5be5764f313ed5b9168a17e6寫成以前的這種

<!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
        $(&#39;input, textarea&#39;).placeholder();
    });
</script>

如果我在這裡為涉及到的或問題依然沒有解決的請移步http://hustlzp.com/post/2014/01/ie8-compatibility更加詳細

以上是bootstrap 不支援ie怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn