> 웹 프론트엔드 > JS 튜토리얼 > innerHTML_javascript 기술 이후 동적 바인딩이 손실되는 EVENT 문제에 대한 솔루션

innerHTML_javascript 기술 이후 동적 바인딩이 손실되는 EVENT 문제에 대한 솔루션

WBOY
풀어 주다: 2016-05-16 17:33:34
원래의
1278명이 탐색했습니다.

innerHTML을 사용하여 콘텐츠 일부를 꺼낸 다음 다시 innerHTML을 사용하면 다음과 같이 동적으로 바인딩된 원본 이벤트가 손실됩니다.
html:

코드 복사 코드는 다음과 같습니다.

클릭
>
스크립트:

코드 복사 코드는 다음과 같습니다.
document.getElementById('d1').onclick =function(){alert(1)};
var html=document.body.innerHTML
document.body.innerHTML=html

이 코드를 실행한 후 d1을 클릭하세요. 응답이 없습니다.

해결책: onclick을 상위 요소에 바인딩하고 버블 원리를 사용하여 현재 요소가 d1인지 확인하고, d1이면

을 실행합니다. 코드 복사 코드는 다음과 같습니다.
document.body.onclick=function(e){
var e=e ||이벤트;
var current=e.target||e.srcElement
if(current.id=='d1'){alert(1)}
}

이것도 접는 방식이 효율에 확실히 영향을 미치게 됩니다.
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿