婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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樣式表的限制分析與解決方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美人体做爰大胆视频| 91精品国产高清一区二区三区 | 在线看日本不卡| 久久午夜电影网| 青青草视频一区| 91浏览器打开| 国产精品麻豆网站| 国产乱人伦偷精品视频不卡| 91精品国产全国免费观看| 亚洲欧美激情小说另类| 成人小视频在线| 久久夜色精品国产噜噜av| 五月天视频一区| 欧美午夜电影网| 一二三区精品福利视频| av中文字幕在线不卡| 国产欧美日韩另类视频免费观看| 免费成人av在线| 日韩午夜小视频| 日韩成人dvd| 欧美一区二区在线播放| 图片区小说区区亚洲影院| 欧美色视频在线| 亚洲h在线观看| 欧美日韩卡一卡二| 日日嗨av一区二区三区四区| 3d成人h动漫网站入口| 亚洲观看高清完整版在线观看 | www精品美女久久久tv| 婷婷中文字幕综合| 欧美一区午夜视频在线观看| 丝袜脚交一区二区| 日韩午夜小视频| 久久精品国产一区二区三| 日韩丝袜美女视频| 韩国毛片一区二区三区| 国产日韩欧美精品一区| 成人高清免费观看| 亚洲精品少妇30p| 欧美日韩精品一区二区三区| 日韩av成人高清| 日韩精品中午字幕| 国产成人在线观看免费网站| 国产精品人人做人人爽人人添| www.亚洲免费av| 一区二区三区在线视频免费 | 国产一区二区日韩精品| 国产亚洲综合在线| 日本韩国精品一区二区在线观看| 亚洲影院免费观看| 欧美一级欧美三级在线观看| 国产在线精品一区二区不卡了 | 五月激情综合婷婷| 日韩免费高清av| 成人免费观看av| 亚洲成人精品一区| 久久网这里都是精品| 91麻豆福利精品推荐| 日本在线不卡视频| 国产精品美女久久久久aⅴ | 亚洲欧美区自拍先锋| 91精品国模一区二区三区| 国产精品亚洲午夜一区二区三区 | 欧美色电影在线| 国产一区二区成人久久免费影院 | 亚洲女人小视频在线观看| 欧美一区午夜精品| 91在线免费看| 精品一区二区三区免费视频| 亚洲丝袜精品丝袜在线| 精品日韩一区二区| 欧美在线|欧美| 丰满少妇久久久久久久 | 亚洲图片欧美综合| 国产网红主播福利一区二区| 欧美视频在线一区二区三区| 国产成人免费视| 麻豆一区二区在线| 亚洲线精品一区二区三区八戒| 国产无人区一区二区三区| 91精品国产欧美日韩| 色综合一个色综合| 国产成人精品免费网站| 秋霞电影网一区二区| 一区二区三区日韩欧美| 国产精品理伦片| 久久久久国色av免费看影院| 51午夜精品国产| 欧美日韩一区二区在线观看视频| a级精品国产片在线观看| 黄网站免费久久| 青青草原综合久久大伊人精品优势| 综合在线观看色| 国产精品毛片a∨一区二区三区| 久久综合精品国产一区二区三区| 欧美高清hd18日本| 欧美日韩亚洲综合| 欧美综合视频在线观看| 色婷婷亚洲综合| 一本到三区不卡视频| eeuss影院一区二区三区| 国产福利一区二区三区| 国产在线不卡视频| 国产在线一区二区综合免费视频| 男男视频亚洲欧美| 日韩高清一区在线| 视频一区二区国产| 秋霞国产午夜精品免费视频| 五月激情六月综合| 蜜臀av国产精品久久久久| 免费看黄色91| 国产永久精品大片wwwapp| 韩国在线一区二区| 国产很黄免费观看久久| 成人在线视频一区| 色婷婷亚洲婷婷| 欧美人伦禁忌dvd放荡欲情| 欧美高清视频www夜色资源网| 日韩欧美精品在线| 久久精品男人天堂av| 中文字幕在线观看一区| 亚洲一二三专区| 日韩精品1区2区3区| 九九九精品视频| 白白色 亚洲乱淫| 日本高清不卡一区| 91超碰这里只有精品国产| 精品精品国产高清一毛片一天堂| 国产亚洲欧美激情| 亚洲激情综合网| 日日夜夜精品免费视频| 国产精品综合久久| 一本色道久久综合亚洲精品按摩| 欧美三级蜜桃2在线观看| 精品国产伦一区二区三区观看方式 | 91美女片黄在线观看91美女| 欧美日韩电影在线播放| 26uuu欧美| 亚洲影院理伦片| 国内国产精品久久| 色噜噜狠狠色综合中国| 日韩免费看网站| 亚洲人成网站影音先锋播放| 丝袜美腿亚洲综合| www.亚洲人| 欧美变态tickle挠乳网站| 亚洲日本成人在线观看| 免费成人在线网站| 一本一本久久a久久精品综合麻豆| 91精品国产美女浴室洗澡无遮挡| 国产欧美日韩一区二区三区在线观看| 一区二区高清在线| 粉嫩蜜臀av国产精品网站| 欧美日韩一区三区| 国产精品欧美一区喷水| 奇米在线7777在线精品| 91丨porny丨户外露出| 2020国产精品久久精品美国| 亚洲综合999| proumb性欧美在线观看| 亚洲精品在线免费播放| 亚洲第一电影网| 91农村精品一区二区在线| 久久你懂得1024| 日本不卡高清视频| 欧美视频三区在线播放| 亚洲欧洲性图库| 国产在线播放一区| 日韩欧美亚洲国产另类| 亚洲成在人线免费| 91浏览器打开| 亚洲欧洲精品一区二区三区不卡| 国产一区二区免费在线| 日韩精品一区二区在线| 日本欧洲一区二区| 欧美日本免费一区二区三区| 亚洲免费电影在线| 色欧美片视频在线观看 | 中文字幕av免费专区久久| 国内精品久久久久影院一蜜桃| 欧美乱妇23p| 婷婷夜色潮精品综合在线| 欧美日韩三级一区二区| 亚洲动漫第一页| 欧美影视一区二区三区| 一区二区成人在线| 91国产免费看| 一区二区久久久| 欧美日韩国产一级| 日韩精品一级二级| 69堂国产成人免费视频| 日本va欧美va精品| 欧美tk—视频vk| 国产高清视频一区| 一区在线播放视频| 在线国产亚洲欧美| 午夜伦理一区二区| 91精品国产乱| 韩国一区二区三区| 国产精品嫩草影院com|