[javascript] 두 요소가 동일한 지 테스트

나는 이것이 처음에는 작동한다고 생각합니다.

if ($('#element') == $('#element')) alert('hello');

하지만 그렇지 않습니다. 요소가 동일한 지 어떻게 테스트합니까?



답변

jquery 1.6부터 이제 간단하게 다음을 수행 할 수 있습니다.

$element1.is($element2)


답변

이것은 작동합니다.

if ($(this)[0] === $(this)[0]) alert('hello');

그래서 이것은

if (openActivity[0] == $(this)[0]) alert('hello');


답변

아니면 그냥

if (openActivity[0] == this) alert('hello');

(새 jQuery 인스턴스없이 😉


답변

누군가 이미 말했듯이 두 개의 다른 순간에 래핑 된 동일한 HTML 요소는 두 개의 다른 jQuery 인스턴스를 생성하므로 결코 같을 수 없습니다.

대신 래핑 된 HTML 요소는 동일한 HTML 요소 인 경우 차지하는 메모리 위치가 동일하기 때문에 이러한 방식으로 비교할 수 있습니다.

var LIs = $('#myUL LI');
var $match = $('#myUL').find('LI:first');

alert(LIs.eq(0) === $match); // false
alert(LIs.get(0) === $match.get(0)) // TRUE! yeah :)

친애하는!


답변

나는 열린 것을 표시하기 위해 addClass ()를 사용하고 쉽게 확인할 수 있습니다.


답변

9 년 후, jQuery없이

두 요소가 동일한 경우 두 요소는 동일한 포인터를 가져야합니다. 그러므로,

document.body === document.body // true
document.querySelector('div') === document.querySelector('div') // true
document.createElement('div') === document.createElement('div') // false


답변

Silky 또는 Santi가 말했듯이 고유 한 ID 또는 클래스가 가장 쉬운 테스트 방법입니다. if 문이 예상대로 작동하지 않는 이유는 두 개체를 비교하고 메모리에서 동일한 개체인지 확인하기 때문입니다.

항상 $ (this)에 의해 생성되는 새로운 객체이기 때문에 서로 같을 수 없습니다. 그래서 객체의 속성을 테스트해야합니다. 각 openActivity 요소에 테스트 할 수있는 다른 콘텐츠가 보장되는 경우 고유 한 ID / 클래스없이 벗어날 수 있습니다.