【问题标题】:how to compare two elements in jquery [duplicate]如何比较jquery中的两个元素[重复]
【发布时间】:2011-01-25 08:31:55
【问题描述】:
var a=$('#start > div:last-child');
var b=$('#start > div.live')[0];
alert(a==b)
alert(a==$(b))

它总是错误的。如何比较 jQuery 中的两个元素?

谢谢

【问题讨论】:

  • @e-motiv 的回答应该是被接受的

标签: javascript jquery dom


【解决方案1】:

为了记录,jQuery 有一个is() 函数:

a.is(b)

请注意,a 已经是一个 jQuery 实例。

【讨论】:

  • 此方法还具有在“==”解决方案不适用的情况下工作的优势:$(event.target).is($("#a"))
  • @DanielS 我认为这里不需要您添加的 2 "$(..)",因为在问题中 a 和 b 已经是 jquery 实例。我也只是为可能认为您必须加倍加载的其他人提及它。
  • @R-U-Bn 你是对的,感谢您指出这一点!对我来说,is() 是一个jQuery API function 更清楚。
  • 我爱你!你拯救了这一天!
  • 这应该是公认的答案。
【解决方案2】:

您可以比较 DOM 元素。请记住,jQuery 选择器返回的数组在引用相等的意义上永远不会相等。

假设:

<div id="a" class="a"></div>

这个:

$('div.a')[0] == $('div#a')[0]

返回真。

【讨论】:

  • 你测试过这个吗?由于.selector 属性的差异,我很确定它不会返回true。
  • 是的,我已经在 IE6、FF 3.6 和 Chrome 4 上测试过这段代码。它在所有这些浏览器上都返回 true
  • 查看@R-U-Bn 下面的评论。以下是诀窍:a.is(b)
  • @mikeycgto 使用数组索引表示法与.get() 相同,而不是.eq()。它们非常不同。
  • 这种比较不起作用。请看R-U-Bn的回答
【解决方案3】:

每次调用 jQuery() 函数时,都会创建并返回一个新对象。所以即使是对同一个选择器的相等检查也会失败。

<div id="a">test</div>

$('#a') == $('#a') // false

生成的 jQuery 对象包含一个匹配元素数组,这些元素基本上是原生 DOM 对象,例如 HTMLDivElement,它们始终引用同一个对象,因此您应该按照 Darin 的建议使用数组索引检查它们是否相等。

$('#a')[0] == $('#a')[0] // true

【讨论】:

  • 感谢您解释为什么不能== 两个 jQuery 对象进行比较
【解决方案4】:
a.is(b)

并检查它们是否不相等使用

!a.is(b)

至于

$b = $('#a')
....
$('#a')[0] == $b[0] // not always true

可能在第一次赋值后添加到元素或从元素中删除类

【讨论】:

  • a.not(b) 不是 a.is(b) 的倒数,而是从 a 中删除元素 b。而是使用 !a.is(b)
  • 是的,你是对的!
【解决方案5】:

在 jQuery 中测试“设置相等性”的随机 AirCoded 示例:

$.fn.isEqual = function($otherSet) {
  if (this === $otherSet) return true;
  if (this.length != $otherSet.length) return false;
  var ret = true;
  this.each(function(idx) { 
    if (this !== $otherSet[idx]) {
       ret = false; return false;
    }
  });
  return ret;
};

var a=$('#start > div:last-child');
var b=$('#start > div.live')[0];

console.log($(b).isEqual(a));

【讨论】:

    【解决方案6】:

    您从 jQuery 集合返回的集合结果不支持基于集合的比较。您可以一一比较各个成员,我知道在 jQuery 中没有这方面的实用程序。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-09-22
      • 2016-05-25
      • 1970-01-01
      • 2011-03-01
      • 1970-01-01
      • 1970-01-01
      • 2012-08-26
      • 1970-01-01
      相关资源
      最近更新 更多