首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过javascript或jQuery删除重复的attr href而保留第一个

如何通过javascript或jQuery删除重复的attr href而保留第一个
EN

Stack Overflow用户
提问于 2017-03-15 09:42:20
回答 3查看 371关注 0票数 0

如何通过Javascript或jQuery删除重复的attr href而保留第一个attr href?

以下是默认代码。并且a.classid不能改变。

代码语言:javascript
复制
<div class="test-class">
  <a href="test-0" class="link">Text0</a> 
  <a href="test-1" class="link">Text1</a> 
  <a href="test-1" class="link">Text1</a> 
  <a href="test-2" class="link">Text2</a>
  <a href="test-2" class="link">Text2</a>
  <a href="test-3" class="link">Text3</a> 
  <a href="test-3" class="link">Text3</a> 
  <a href="test-3" class="link">Text3</a> 
</div>

我需要这样做:

代码语言:javascript
复制
<div class="test-class">
  <a href="test-0" class="link">Text0</a> 
  <a href="test-1" class="link">Text1</a> 
  Text1
  <a href="test-2" class="link">Text2</a>
  Text2
  <a href="test-3" class="link">Text3</a> 
  Text3
  Text3
</div>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-03-15 09:54:14

类似这样的代码可以大致实现您正在寻找的功能:

代码语言:javascript
复制
let tracker = {}; // track href values

$('a').each(function(anc) {
  var href = $(this).attr('href');
  if (tracker.hasOwnProperty(href)) {
    $(this).replaceWith(`<div>${$(this).text()}</div>`);
  } else {
    tracker[href] = true;
  }
});
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="test-class">
  <a href="test-0" class="link">Text0</a>
  <a href="test-1" class="link">Text1</a>
  <a href="test-1" class="link">Text1</a>
  <a href="test-2" class="link">Text2</a>
  <a href="test-2" class="link">Text2</a>
  <a href="test-3" class="link">Text3</a>
  <a href="test-3" class="link">Text3</a>
  <a href="test-3" class="link">Text3</a>
</div>

票数 1
EN

Stack Overflow用户

发布于 2017-03-15 10:12:50

你可以尝试使用下面的javascript:

代码语言:javascript
复制
var hrefTags = document.getElementsByTagName('A');
var arrValue = [];
for (var i=0; i<hrefTags.length; i++){
  if(arrValue.indexOf(hrefTags[i].innerHTML)>-1){
    hrefTags[i].outerHTML = hrefTags[i].outerHTML.replace(/a/g, 'span');
    i--;
  } else {
    arrValue.push(hrefTags[i].innerHTML);
  }
}
代码语言:javascript
复制
<div class="test-class">
  <a href="test-0" class="link">Text0</a> 
  <a href="test-1" class="link">Text1</a> 
  <a href="test-1" class="link">Text1</a> 
  <a href="test-2" class="link">Text2</a>
  <a href="test-2" class="link">Text2</a>
  <a href="test-3" class="link">Text3</a> 
  <a href="test-3" class="link">Text3</a> 
  <a href="test-3" class="link">Text3</a> 
</div>

票数 0
EN

Stack Overflow用户

发布于 2017-03-15 10:25:36

很抱歉回复晚了,但这是我的答案::D

代码语言:javascript
复制
$(window).on('load',function() {
    var last_elm = $('a[href]:first').text();
    $('a[href]').each(function(i) {
        var content = $(this).text();
        if (i && content==last_elm) $(this).replaceWith('<span>'+content+'</span>');
        last_elm=content;
    });
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42799715

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档