>웹 프론트엔드 >JS 튜토리얼 >ASP.NET UpdatePanel 업데이트 후 jQuery 이벤트 바인딩을 어떻게 유지합니까?

ASP.NET UpdatePanel 업데이트 후 jQuery 이벤트 바인딩을 어떻게 유지합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-05 13:44:10235검색

How Can I Maintain jQuery Event Binding After ASP.NET UpdatePanel Updates?

UpdatePanel 업데이트에 jQuery 이벤트 바인딩 적용

UpdatePanels 내에 jQuery 이벤트 처리를 통합하면 부분 페이지 업데이트 중 요소 교체로 인해 문제가 발생합니다. .

초기 바인딩에 $(document).ready를 사용하면 다음과 같습니다. 불충분하다. 문제에 명시된 대로 업데이트 후 "UpdatePanel 내에서 실행되지 않고 마우스 오버 효과가 더 이상 작동하지 않습니다."

권장 접근 방식: PageRequestManager 활용

이 문제를 해결하려면 UpdatePanel을 업데이트할 때마다 이벤트를 다시 구독하는 것이 좋습니다. PageRequestManager를 통해 액세스되는 ASP.NET ajax 수명 주기가 솔루션을 제공합니다.

다음 코드는 이 접근 방식을 보여줍니다.

$(document).ready(function() {
    // bind jQuery events initially
});

var prm = Sys.WebForms.PageRequestManager.getInstance();

prm.add_endRequest(function() {
    // re-bind jQuery events
});

UpdatePanel이 있는 경우 액세스할 수 있는 PageRequestManager는 endRequest를 제공합니다. 업데이트가 완료되면 트리거되는 이벤트입니다. 이 이벤트를 사용하면 jQuery 이벤트를 다시 바인딩할 수 있습니다.

대체 옵션: jQuery .on()

상황에 따라 jQuery의 .on() 메서드가 제공될 수 있습니다. 더 효율적인 대안. .on()을 사용하면 요소의 컨테이너에 바인딩할 수 있으므로 업데이트할 때마다 다시 바인딩할 필요가 없습니다. 그러나 이 접근 방식의 한계를 고려하고 특정 요구 사항에 적합한지 확인하는 것이 중요합니다.

위 내용은 ASP.NET UpdatePanel 업데이트 후 jQuery 이벤트 바인딩을 어떻게 유지합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.