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 중국어 웹사이트의 기타 관련 기사를 참조하세요!