program story

두 요소가 동일한 지 테스트

inputbox 2020. 9. 23. 07:35
반응형

두 요소가 동일한 지 테스트


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

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 / 클래스없이 벗어날 수 있습니다.

참고 URL : https://stackoverflow.com/questions/1269926/test-if-two-elements-are-the-same

반응형