나는 이것이 처음에는 작동한다고 생각합니다.
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 / 클래스없이 벗어날 수 있습니다.