好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > IE對CSS樣式表的限制分析與解決方案

IE對CSS樣式表的限制分析與解決方案

熱門標簽:ai電話機器人效果差 地圖標注微信好友 南昌電話機器人系統 沈陽400電話辦理多少錢 蘇州做電話機器人 隨州外呼系統廠家 南山電話機器人 地圖標注樓盤 快速更改地圖標注點標
HTML文檔與CSS的關聯常見有4種方式:

使用link標記

link rel="stylesheet" type="text/css" href="sheet.css" />
使用style元素

style type="text/css">
body{background:#fff;}
h1{font-size:2em;}
/style>
使用@import指令

style type="text/css">
@import url(sheet1.css);
@import "sheet2.css";
/style>
使用style屬性的內聯樣式(inline style)

p style="color:#f00;">這是紅色的字/p>
在實際應用中,使用style屬性的內聯樣式是不推薦使用的,XHTML1.1已經將其標準為不建議使用,原因很簡單這種方式不比font標記強多少,削弱了CSS集中控制整個文檔外觀的優點。前3種方式利用了link標記和style標記,在IE(包括IE6、IE7和IE8 beta1)中有如下限制:

文檔中只有前31個link或style標記關聯的CSS能夠應用。

從第32個開始,其標記關聯的CSS都將失效。IE的官方文檔All style tags after the first 30 style tags on an HTML page are not applied in Internet Explorer也提及這個限制,包括在使用.xsl的.xml文件也有這個限制。但是似乎寫錯了數量。請在IE看:

例1:34個style標記同時應用
例2:1個style標記和34個link標記同時應用
一個style標記只有前31次@import指令有效應用。

從第32個@import指令開始忽略。請看:

例3:在一個style標記中使用34次@import指令。

一個css文件只有前31次@import指令有效應用。

從第31個@import指令開始忽略。請看:

例4:用link標記引入一個使用34次@import指令的css文件
例5:用style標記引入一個使用34次@import指令的css文件
例6:用link和style標記分別引入一個使用31次@import指令以上的css文件
一個CSS文件的不能超過288kb?

這個消息來自Internet Explorer CSS File Size Limit。

@import指令下層疊限制不能超過4層

在IE下通過@import指令引入css文件時,第5層會失效。這個限制來自Cascade limit via @import rule。實際上,由于瀏覽器對多層嵌套的支持不完善,所以即使不得已使用了@import指令引入CSS文件,也不要超過2層。

IE對CSS的限制在絕大部分情況下是不會遇到的,即使遇到最佳的解決方案也應該是手動或者通過后端程序對CSS文件和響應的標記進行合并,最小化的http請求數是優化頁面呈現的第一原則。

在IE中,可以通過document.styleSheets對象(Firefox、Opera9和Safari3.1都支持)修改內聯和嵌入樣式的值。該對象僅在文檔包含style或link元素時可用,其實用document.styleSheets.length就可以看出IE下這個值最大是31。下面是利用Javascript來合并link和style標記來解決IE下的限制:

var fnMergeStyleSheet = function(){
if(!document.styleSheets){
    return;
}
var aSheet = document.styleSheets,
    aStyle = document.getElementsByTagName('style'),
    aLink  = document.getElementsByTagName('link');
    if(aStyle.length + aLink.length  32 || !aSheet[0].cssText){
        //document.styleSheets.cssText只有IE支持
        return;
    }
    var aCssText = [],aCloneLink = [];
    //把style標簽中的樣式存入,然后刪掉該標簽,但保留第一個
    //因為由getElementsByTagName方法返回值是nodeList,所以刪除時循環用倒序
    for(var i=aStyle.length-1;i>-1;–i){
        var o = aStyle[i];
            aCssText.push(o.innerHTML);
            if(i>0){
                o.parentNode.removeChild(o);
            }
    }
    //在IE中只有在31之內的link標簽才能通過其styleSheet.cssText獲取樣式
       //無法的獲取復制到一個數組aCloneLink中
    for(var i=aLink.length-1;i>-1;–i){
       var o = aLink[i];
          if(o.getAttribute  o.getAttribute('rel')==='stylesheet'){
               if(o.styleSheet){
                  aCssText.push(o.styleSheet.cssText);
               }else{
                   aCloneLink.push(o.cloneNode(true));
               }
               if(i>0){
                   o.parentNode.removeChild(o);
               }
          }
    }
    var oHead = document.getElementsByTagName('head')[0];
    //通過前面的刪除,前31個link或者style標記最多只剩下2個
    //通過重新增加link節點的方法激活其styleSheet屬性,從而獲取樣式
    for(var i = aCloneLink.length-1;i>-1;–i){
        var o = aCloneLink[i];
        oHead.appendChild(o);
        aCssText.push(o.styleSheet.cssText);
        oHead.removeChild(o);
    }
   //把所有的樣式都復制給第一個標簽
    aSheet[0].cssText += aCssText.join(”);
}
上面僅僅是一個簡單的粗糙的解決方案,演示請看例1和例2,可以改進的地方還有:

沒有考慮media這個屬性,如果有多個media應該分別合并,當然更沒有考慮link標記的rel="alternate stylesheet"帶來的影響。但我更建議通過@media指令把相應的樣式寫在同一個文件中,至少可以減少HTTP連接數。 
沒有解決@import指令31次限制的問題,其實可以提取其href值然后進行激活處理。但是實際應用在建議用link標記來替代@import指令,應為在IE中@import指令相當與把link標記寫在文檔的底部,會導致在IE5/6頁面加載時瞬間無樣式問題,學名叫“Flash of Unstyled Content”(簡稱為FOUC)的bug,當然可以通過在文檔頭中放一個link或script元素可以避免這個bug。 
一般來講頁面之所有出現大量的link或者style標簽很可能有很多是相同的,可以在aCssText合并前除掉相同的項,減少代碼量。 
如果不用DOM中已存在的樣式元素直接通過cssText屬性添加樣式代碼,而是創建一個新的樣式元素來添加,一定要注意先把新建的樣式元素先添加到DOM中,然后再通過cssText屬性添加樣式代碼。反之,其添加的樣式代碼似乎先被IE6的樣式解析器解析后才添加,這樣!imporant和hack都將失效。請看例7。不建議通過添加新的樣式元素的方式來添加新的樣式,這樣很容易達到IE的限制條件。

標簽:深圳 濰坊 石家莊 昭通 商洛 玉樹 大同 濰坊

巨人網絡通訊聲明:本文標題《IE對CSS樣式表的限制分析與解決方案》,本文關鍵詞  對,CSS,樣式,表,的,限制,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《IE對CSS樣式表的限制分析與解決方案》相關的同類信息!
  • 本頁收集關于IE對CSS樣式表的限制分析與解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 性夜影院爽黄a爽在线看香蕉| 80s成人片无码免费看| 黄色尻逼| j8又粗又硬又大又爽又长视频| 欧美黑人xxxx| 精品日韩午夜婷不卡91综合在线| 经典黄色片| 欧美一级婬片A片免费播放绣春 | 全黄裸片武则天一级在线| 《守望人妻电影》波多野结衣| 亚洲第一页国产| 欧洲风流少妇XXXXⅩO69| 久久妻| 国产另类在线欧美日韩| 女教师三上悠亚SSNI-542| 看看免费a一片欧| 美女极品粉嫩美鲍35p| 日韩欧美一区二区三区精品| 免费男女囗交视频| 哦┅┅快┅┅用力┅| 国产V亚洲V天堂无码久久鲜肉| 摸老师丝袜小内内摸出水| 男人女人差差差| SIS001第一会所亚洲原创| 欧美精品束缚一区二区三区| 国产精品视频流白浆免费视频| 久久久久久AV无码免费网站下载| 欧美高清成人| 黄色app免费| 国产欧美一区二区精品性| 欧美护士性极品hd4k| 日本japanesexxxx老师| 日本边摸边吃奶边做叫床视频 | 三个男人躁我一个认真的后果及影响| 强app8499小说网站| A片视频黑人又粗又大XXXXX| 欧美视频二区| 美女被日出水| 纳西妲被触手钻进腹中怀孕| 日本免费色网站| 向日葵视频app色版|