手机
当前位置:查字典教程网 >网页设计 > Div+Css教程 >IE下href 的 BUG问题
IE下href 的 BUG问题
摘要:复制代码代码如下:test(function(){vartest=document.getElementById('test');alert...

复制代码 代码如下:

<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 新值):

复制代码 代码如下:

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》

【IE下href 的 BUG问题】相关文章:

CSS关于解决图片元素下多余空白的BUG

IE与Firefox的CSS兼容大全

CSS学习中的瓶颈

CSS在IE与Firefox下的兼容性

CSS出现overflow的一些问题

CSS编写小技巧

相同元素不同结构重复定义的问题

VB中Byval和byref的区别

最全的CSS浏览器兼容问题

关于几个常见的css字体设定问题探讨

精品推荐
分类导航