a.getAttribute(“href”) 返回 img src 而不是 href

a.getAttribute("href") returns img src instead of a href

本文关键字:href src img 返回 getAttribute      更新时间:2023-09-26

我们这里有一个问题:如果 href 不包含特定域,这个小脚本应该编辑链接的 href 属性。不幸的是,当<a>元素包含<img>时,JS将查找图像的src属性,而不是a的href。为什么?我只是在<a>上使用getAttribute("href"),而不是在<img>上使用?

如果 <a> 元素确实包含普通文本而不是<img>,则它可以工作。

这是JS:

var domains = ["mysite.com", "mysite2.com"];
var elements = document.getElementsByTagName("a");
for (var i = 0; i < elements.length ; i++)
{
    var notFound = 0;
    for (var k = 0; k < domains.length; k++) //iterate over all domains defined by user
    {
        var found = false;
        (elements[i].getAttribute("href").search(domains[k]) != -1) ? found = true : found = false; 
        if (!found) //not found
        {
            notFound++;
        }
    }
    if (notFound == domains.length) //link is outbound:
    {
        //Set link with outbound tracking parameter
    }
}

这是 HTML:

<a href="http://facebook.com/38293729">
    <img width="100%" height="100%" src="http://mysite.com/images/fb_button.png"></img>
</a>

有人可以解释这种行为并为我们提供提示或解决方案吗?提前致谢

一月

这当然是PEBKAC或ID-10-T错误。

其中一个链接是:

<a href="http://facebook.com/38293729/?utm_source=mysite.com&utm_medium=socialbutton&utm_campaign=socialbutton">
<img src="http://mysite.com/facebookbutton.png"></img>
</a>

与网址参数匹配的位置:

a href="http://facebook.com/38293729/?utm_source=mysite.com&utm_medium=社交按钮&utm_campaign=社交按钮"