Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > html5

IE下href 的 BUG问题

来源:中文源码网    浏览:220 次    日期:2024-05-08 15:15:36
【下载文档:  IE下href 的 BUG问题.txt 】


IE下href 的 BUG问题
复制代码 代码如下:
结果会发现,在 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》

相关内容