> 웹 프론트엔드 > JS 튜토리얼 > innerHTML 수정 시 이벤트 리스너 손실을 방지하려면 어떻게 해야 합니까?

innerHTML 수정 시 이벤트 리스너 손실을 방지하려면 어떻게 해야 합니까?

Patricia Arquette
풀어 주다: 2024-12-15 19:40:19
원래의
533명이 탐색했습니다.

How Can I Prevent Event Listener Loss When Modifying innerHTML?

innerHTML에 추가할 때 이벤트 리스너 보존

상위 노드의 innerHTML에 할당할 때 하위 항목에 연결된 이벤트 핸들러가 삭제될 수 있습니다. 예를 들어, 코드를 고려해보세요 아래:

<div><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><span>
로그인 후 복사

< script>

mydiv = document.getElementById("mydiv");
mydiv.innerHTML += "bar";
로그인 후 복사


여기, "foo"가 포함된 범위에 연결된 onclick 이벤트 핸들러는 mydiv.innerHTML에 할당된 후 삭제됩니다.

이 문제를 방지하려면 .innerHTML 대신 .insertAdjacentHTML() 메서드를 사용하세요. 이 방법은 이벤트 리스너를 유지하며 모든 주요 브라우저에서 지원됩니다.

<script></p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var html_to_insert = "<p>New paragraph</p>";
document.getElementById('mydiv').insertAdjacentHTML('beforeend', html_to_insert);
로그인 후 복사


'beforeend' 인수는 요소에서 HTML 콘텐츠를 삽입할 위치를 지정합니다. 다른 옵션으로는 'beforebegin', 'afterbegin' 및 'afterend'가 있습니다.

위 내용은 innerHTML 수정 시 이벤트 리스너 손실을 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
이전 기사:`setState`가 React 구성 요소 상태를 즉시 업데이트하지 않는 이유는 무엇입니까? 다음 기사:ES6 화살표 기능이 있는 jQuery 클릭 핸들러에서 `$(this)`가 실패하는 이유는 무엇입니까?
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
관련 주제
더>
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿