> 웹 프론트엔드 > JS 튜토리얼 > 다양한 브라우저에서 브라우저 뒤로 버튼 누르기를 안정적으로 감지하려면 어떻게 해야 합니까?

다양한 브라우저에서 브라우저 뒤로 버튼 누르기를 안정적으로 감지하려면 어떻게 해야 합니까?

Barbara Streisand
풀어 주다: 2024-12-17 03:46:24
원래의
115명이 탐색했습니다.

How Can I Reliably Detect Browser Back Button Presses Across Different Browsers?

브라우저 전반에서 브라우저 뒤로 버튼 이벤트 감지

브라우저 뒤로 버튼의 동작을 감지하는 것은 비동기식 특성으로 인해 문제가 발생합니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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