브라우저 전반에서 브라우저 뒤로 버튼 이벤트 감지
브라우저 뒤로 버튼의 동작을 감지하는 것은 비동기식 특성으로 인해 문제가 발생합니다. window.onhashchange 활용과 같은 일부 방법이 있지만 해시 변경을 트리거하는 페이지 내 요소와 실제 뒤로 버튼 누르기를 구별하지 못합니다.
페이지 내 뒤로 버튼 사용 시행
해시 탐색에 의존하는 단일 페이지 애플리케이션에서는 뒤로 버튼의 기능을 조절하는 것이 중요합니다. 해시를 수정하는 페이지 내 뒤로 버튼을 사용하면 탐색에 대한 제어를 유지할 수 있습니다.
브라우저 뒤로 버튼 누르기 검색
브라우저 뒤로 버튼 이벤트를 정확하게 감지하려면 , 마우스를 가리키고 문서에 이벤트를 남기는 크로스 플랫폼 접근 방식을 고려해보세요.
document.onmouseover = function() { // User's cursor is within the document area window.innerDocClick = true; } document.onmouseleave = function() { // User's cursor has exited the document area window.innerDocClick = false; } window.onhashchange = function() { if (window.innerDocClick) { // Navigation triggered by in-page action } else { // Browser back button was pressed } }
이 방법은 부울 값을 설정합니다. 커서가 문서 영역 내에 있는지 여부를 나타내는 플래그(window.innerDocClick)입니다. 플래그가 false인 동안 해시가 변경되면 브라우저 뒤로 버튼을 누르도록 제안합니다.
백스페이스가 뒤로 이벤트를 트리거하지 않도록 방지
백스페이스 키가 뒤로 버튼을 사용하려면 다음 jQuery 코드를 사용하세요.
$(function(){ var rx = /INPUT|SELECT|TEXTAREA/i; $(document).bind("keydown keypress", function(e){ if( e.which == 8 ){ // 8 == backspace if(!rx.test(e.target.tagName) || e.target.disabled || e.target.readOnly ){ e.preventDefault(); } } }); });
이 코드는 백스페이스 누르기를 가로채서 뒤로가기 버튼을 누르는 것을 방지합니다. 입력란에 포커스가 없을 경우 버튼 이벤트
위 내용은 다양한 브라우저에서 브라우저 뒤로 버튼 누르기를 안정적으로 감지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!