源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 642|回复: 14

[CSS/HTML] IE下href 的 BUG问题

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2008-11-18 13:56:26 | 显示全部楼层 |阅读模式
在浏览器 IE6 、IE7、Firefox2+、Firefpx3+、Opera9.6+、Safari3.1+中测试以下代码 复制代码 代码如下:
<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》

  • 回复

    使用道具 举报

    4

    主题

    1万

    回帖

    60

    积分

    注册会员

    Rank: 2

    积分
    60
    发表于 2022-8-9 01:05:02 | 显示全部楼层
    sdsadsadsadf
    回复 支持 反对

    使用道具 举报

    6

    主题

    1万

    回帖

    174

    积分

    注册会员

    Rank: 2

    积分
    174
    发表于 2022-12-9 04:46:56 | 显示全部楼层
    看到这帖子真是高兴!
    回复 支持 反对

    使用道具 举报

    2

    主题

    2万

    回帖

    380

    积分

    中级会员

    Rank: 3Rank: 3

    积分
    380
    发表于 2023-2-25 17:39:13 | 显示全部楼层
    哟哟哟哟哟以偶
    回复 支持 反对

    使用道具 举报

    4

    主题

    2万

    回帖

    303

    积分

    中级会员

    Rank: 3Rank: 3

    积分
    303
    发表于 2023-4-22 01:48:43 | 显示全部楼层
    看看看咋么
    回复 支持 反对

    使用道具 举报

    1

    主题

    2万

    回帖

    176

    积分

    注册会员

    Rank: 2

    积分
    176
    发表于 2023-8-22 14:02:16 | 显示全部楼层
    好人好人好人好人
    回复 支持 反对

    使用道具 举报

    1

    主题

    1万

    回帖

    51

    积分

    注册会员

    Rank: 2

    积分
    51
    发表于 2024-5-27 19:20:53 | 显示全部楼层
    这个源码不错啊
    回复 支持 反对

    使用道具 举报

    5

    主题

    2万

    回帖

    183

    积分

    注册会员

    Rank: 2

    积分
    183
    发表于 2024-5-28 09:42:31 | 显示全部楼层
    还有人在不。。。。。。。。。。啊
    回复 支持 反对

    使用道具 举报

    1

    主题

    2万

    回帖

    69

    积分

    注册会员

    Rank: 2

    积分
    69
    发表于 2024-7-24 16:47:21 | 显示全部楼层
    撒房产税陈飞飞
    回复 支持 反对

    使用道具 举报

    2

    主题

    2万

    回帖

    499

    积分

    中级会员

    Rank: 3Rank: 3

    积分
    499
    发表于 2024-8-30 13:58:39 | 显示全部楼层
    看看看看看看看看看看看看看看看看看看看看看看看看看看看
    回复 支持 反对

    使用道具 举报

    高级模式
    B Color Image Link Quote Code Smilies

    本版积分规则

    手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

    GMT+8, 2024-11-22 08:31 , Processed in 0.082265 second(s), 26 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2020, Tencent Cloud.

    快速回复 返回顶部 返回列表