麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

全系IE支持Bootstrap的解決方法

2024-05-06 16:24:42
字體:
來源:轉載
供稿:網友

用了bootstrap模版搭建的網站,在IE7中打不開,在IE8中背景圖片都不顯示,內容排列也出現問題,在IE9中表現的最好,在IE11中出現彈出層中的圖片無法顯示,那么這些兼容性怎么去解決

最近做一個Web網站,之前一直覺得bootstrap非常好,這次使用了bootstrap3,在chrome,firefox,safari,opera,360瀏覽器(極速模式)、搜狗瀏覽器等瀏覽器下均沒有問題,而在IE8及IE11下發現樣式無法顯示,然后各種百度啊,最后在一個網友帖子的幫助下解決了問題,先將解決方法總結如下:

首先需要確保你的HTML頁面開始部分要有DOCTYPE聲明。DOCTYPE告訴瀏覽器使用什么樣的HTML或XHTML規范來解析HTML文檔,具體會影響:

對標記attributes 、properties的約束規則

對瀏覽器的渲染模式產生影響,不同的渲染模式會影響到瀏覽器對于CSS代碼甚至JavaScript腳本的解析

DOCTYPE是非常關鍵的,目前的最佳實踐就是在HTML文檔的首行鍵入:

 

 
  1. <!DOCTYPE html> 

大神的帖子總結的bootstrap的查找原因好幾條,首先,Bootstrap3 是移動設備優先的原則開發的,所以原因可能如下:

1.沒有正確調用遠程地址

即只要是IE9以下,就調用兩個專門的js

 

 
  1. <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries --> 
  2. <!--[if lt IE 9]> 
  3. <script src="http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script> 
  4. <script src="http://apps.bdimg.com/libs/respond.js/1.4.2/respond.min.js"></script> 
  5. <![endif]--> 

但是我測試發現僅僅使用以上js文件不可行,

2.調用方法不正確

不要用file://或@import形式引用respond.min.js或respond.js或css文件

3.針對瀏覽器的內容做標識

(使用meta標簽調節瀏覽器的渲染方式)

bootstrap不支持IE兼容模式,為了讓IE瀏覽器運行最新的渲染模式,將添加以下標簽在頁面中

 

IE=edge表示強制使用IE最新內核,chrome=1表示如果安裝了針對IE6/7/8等版本的瀏覽器插件Google Chrome Frame(可以讓用戶的瀏覽器外觀依然是IE的菜單和界面,但用戶在瀏覽網頁時,實際上使用的是Chrome瀏覽器內核),那么就用Chrome內核來渲染。關于此meta標簽的具體說明,可參見StackOverflow上的精彩回答,

標簽高人的英文解釋可以參看

http://stackoverflow.com/questions/6771258/whats-the-difference-if-meta-http-equiv-x-ua-compatible-content-ie-edge-e

我有加了一句

 

然后就可以了

內核控制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

 

 
  1. <link rel="stylesheet" type="text/css" href="bootstrap.min.css" media="screen"/> 
  2. <script type="text/javascript" src="js/respond.min.js"></script> 

6.DOCTYPE前后有空行

 

這里有空格也不行,要去掉空格

 

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

 

這個我測試過,不可行

最后我在IE11下測試通過,但是在IE8下測試,有發現一個問題placeholder不被支持

下面是解決IE支持placeholder的方法

本文引用的jquery是1.11.1測試通過,先引用jquery

 

 
  1. <script type="text/javascript" src="http://code.jquery.com/jquery-1.11.1.min.js"></script> 

也可以用其他的jquery版本

再引入

jquery.placeholder.js這個文件的下載地址https://github.com/mathiasbynens/jquery-placeholder

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

 

 
  1. <script type="text/javascript"
  2. $(function () { 
  3. // Invoke the plugin 
  4. $('input, textarea').placeholder(); 
  5. }); 
  6. </script> 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: av91肉丝一区二区电影 | 成人精品免费在线观看 | 久草在线视频网 | 国产羞羞视频在线观看免费应用 | 精品国产乱码久久久久久丨区2区 | 国产精品久久久久久久久久久久久久久久 | 久久亚洲一区二区三区成人国产 | 亚洲综人网 | 精品国产乱码久久久久久久 | 国产精品亚洲欧美一级在线 | 国产一级毛片av | 欧美成人免费在线视频 | 男女一边摸一边做羞羞视频免费 | 亚洲国产精品一区二区精品 | 日本网站在线看 | 麻豆视频网 | 看一级毛片 | 日日操夜夜操视频 | 国产午夜精品久久久久 | 天堂成人国产精品一区 | 日本精品免费观看 | 国产精品久久久久久婷婷天堂 | 久久6国产 | 欧美18—19sex性hd | 久久6国产| 欧美伦理一区二区 | 污污的视频在线观看 | 久久亚洲精品国产一区 | 色妇视频 | xxxx69hd一hd72| 250pp久久新 黄色网址免费在线播放 | 久久99国产综合精品 | 午夜视频中文字幕 | 成人店女老板视频在线看 | 国产91一区 | 黄色网址免费在线播放 | 成人福利网 | 性爱视频在线免费 | 免费黄色短视频网站 | 国产人妖一区二区 | 欧美一级高清片在线 |