当前位置: 首页 > 图文教程 > 网页制作 > HTML/XHTML教程 > IE 下 href 的 BUG

HTML/XHTML教程
网页设计中文本输入框的一些参数说明
XHTML CSS写出正规的BLOG
初学者接触HTML了解一些HTML标记(1)
网页设计学习XHTML应用小结
常用的XHTML标签的使用技巧介绍
HTML网页META标签内容写作规范要点
XHTML 1.0 参考
HTML的一些关于颜色方面的参考
你问我答:XML与HTML的区别
入门:HTML的基本标签和属性简单介绍
带有图片预览功能的上传表单的完整HTML
HTML表格标记教程(10):单元格边距属性CELLPADDING
HTML表格标记教程(11):水平对齐属性ALIGN
HTML表格标记教程(12):边框样式属性FRAME
HTML表格标记教程(8):背景图像属性BACKGROUND
HTML表格标记教程(9):单元格间距属性CELLSPACING
HTML表格标记教程(6):暗边框色属性BORDERCOLORDARK
HTML表格标记教程(7):背景颜色属性BGCOLOR
HTML表格标记教程(5):亮边框色属性BORDERCOLORLIGHT
HTML表格标记教程(3):宽度和高度属性WIDTH、HEIGHT

HTML/XHTML教程 中的 IE 下 href 的 BUG


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 58 ::
收藏到网摘: n/a

在浏览器 IE6 、IE7、Firefox2+、Firefpx3+、Opera9.6+、Safari3.1+中测试以下代码(Demo):

<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 值成为了绝对路径。

其实先人们早遇到这些问题(感谢 玉伯 提供的资料):

在上面的文章中已提及了处理方案,就是在 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 新值):

sHref = 'http://www.hedgerwow.com';
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》