6

我有这个:

<span class="image"><img src="something.jpg"></span>

我想使用 javascript 将其转换为:

<span class="image"><a href="domain"><img src="something.jpg"></a></span>

必须使用 javascript 来隐藏附属链接。

我已经尝试过这个脚本,但它似乎不起作用:

function changespan() {
find all <span> tags;
for each <span> with class="image"{
URL = "http://domain.com"
Create new link to URL;
insert link into <span>;
}       
}

该函数在文件 script.js 中上传,我以这种方式加载它:

<script type="text/javascript" src="script.js"></script>
<script type="text/javascript">
window.onload = changespan;
</script>

编辑:解决这个问题后,我如何解析我的页面以找到这种格式的链接:然后将此值分配给变量 URL。我需要能够将 URL_1 的第一个路径分配给 URL_2,依此类推。

4

2 回答 2

8

这是您可以实现它的方式:

function changespan() {
    var spans = document.querySelectorAll('span.image');
    for (var i = spans.length; i--; ) {
        var a = document.createElement('a');
        a.href = "http://domain.com";
        spans[i].appendChild(a).appendChild(a.previousSibling);
    }
}

http://jsfiddle.net/Tqv76/1/

于 2013-03-11T13:47:18.173 回答
4

在这里,我将它翻译成 JavaScript,以保持你的伪代码尽可能完整

演示

window.onload=function() {
  var spans = document.getElementsByTagName("span"); // or the newer querySelectorAll
  for (var i=0;i<spans.length;i++) {
    if (spans[i].className=="image") {
      var link = document.createElement("a");
      link.href = "http://domain.com";
      link.setAttribute("rel","nofollow");
      link.className="someclass";
      link.innerHTML=spans[i].innerHTML;
      spans[i].replaceChild(link,spans[i].getElementsByTagName('img')[0]);
    }       
  }
}
于 2013-03-11T13:46:17.617 回答