国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

IE下href 的 BUG問題

2020-10-23 18:29:58
字體:
來源:轉載
供稿:網友
復制代碼 代碼如下:

<div id="test">
<a href="#"> test </a>
</div>
<div id="result"></div>

<script type="text/javascript">
(function(){
var test = document.getElementById('test');
alert(test.innerHTML);

var result = document.getElementById('result');
result.innerHTML = test.innerHTML;
alert(result.innerHTML)
})();
</script>

結果會發現,在 IE6、IE7 瀏覽器中第二次彈出的 result.innerHTML 中的 A 元素的 href 值成為了絕對路徑。
其實先人們早遇到這些問題(感謝 玉伯 提供的資料):
  • 《getAttribute(”HREF”) is always absolute》
  • 《getAttribute href bug》
    在上面的文章中已提及了處理方案,就是在 IE 下使用 getAttribute( ‘href' , 2 ) 方法。 Microsoft 給此方法擴展了第二個參數,可設置為 0、1、2,如果設置為 2 ,則返回屬性原始值。
    腳本修正為:
    復制代碼 代碼如下:

    (function(){
    var test = document.getElementById('test');
    alert(test.innerHTML);
    var result = document.getElementById('result');
    result.innerHTML = test.innerHTML;
    if(/*@cc_on!@*/0 ) { //if ie
    var links1 = test.getElementsByTagName('a');
    var links2 = result.getElementsByTagName('a');
    for(var i = 0, len = links1.length; i < len; ++i ) {
    links2[i].href = links1[i].getAttribute('href', 2);
    }
    }
    alert(result.innerHTML);
    })();

    在尋找此問題的過程中還搜索到 Hedger Wang 發現的一個有趣的 BUG 問題:在 IE 中當重新設置新的 href 屬性值時,如果鏈接文字含有 “http://” 或 “@” ,則其 innerHTML 將顯示不正確,顯示成設置的 href 屬性。
    解決方法(sHref 為要設置的 href 新值):
    復制代碼 代碼如下:

    s;
    var isMSIE = /*@cc_on!@*/false;
    if( isMSIE ){
    sHref = ' ' + sHref; //add extra space before the new href
    };

    詳細:《Internet Explorer might reset Anchor's innerHTML incorrectly when a new “href” is assigned》

  • 發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    主站蜘蛛池模板: 正阳县| 上杭县| 合水县| 余江县| 武隆县| 保靖县| 光山县| 肇源县| 华宁县| 大新县| 永和县| 东港市| 万源市| 新竹市| 西丰县| 祁门县| 成安县| 平乐县| 会同县| 敦煌市| 昌宁县| 惠安县| 安徽省| 东丽区| 湘西| 栖霞市| 车致| 焦作市| 周至县| 慈利县| 原阳县| 博乐市| 买车| 宝兴县| 霍林郭勒市| 钟山县| 三河市| 上杭县| 封开县| 曲靖市| 延庆县|