> 웹 프론트엔드 > 프런트엔드 Q&A > 자바스크립트 웹페이지 닫기 이벤트에 대해 이야기해보겠습니다.

자바스크립트 웹페이지 닫기 이벤트에 대해 이야기해보겠습니다.

PHPz
풀어 주다: 2023-04-24 10:01:15
원래의
2871명이 탐색했습니다.

JavaScript 웹페이지 종료 이벤트

글로벌 인터넷의 인기로 인해 웹페이지 애플리케이션이 점점 더 대중화되고 있습니다. 사용자 경험을 향상시키기 위해서는 몇 가지 웹페이지 상호작용 기술을 숙달해야 합니다. 그 중에서 웹페이지 닫기 이벤트는 웹페이지가 닫히기 전에 데이터 제출, 사용자 정보 저장 등과 같은 특정 작업을 수행하는 데 도움이 될 수 있는 매우 중요한 이벤트입니다.

이 글에서는 JavaScript의 웹 페이지 닫기 이벤트를 소개하고 독자가 이 이벤트를 더 잘 배우고 이해하는 데 도움이 되는 몇 가지 실용적인 예와 기술을 제공합니다.

  1. 웹 페이지 닫기 이벤트의 의미

웹 페이지 닫기 이벤트는 사용자가 현재 웹 페이지를 닫을 때 브라우저가 이벤트를 트리거하여 JavaScript를 통해 특정 작업을 수행할 수 있다는 의미입니다. 이러한 작업에는 데이터 제출, 캐시 지우기, 쿠키 삭제 등이 포함될 수 있습니다.

기존 웹 애플리케이션에서는 웹 페이지가 정보를 표시하는 데에만 사용되며 사용자 작업에 응답할 필요가 없기 때문에 웹 페이지 닫기 이벤트는 중요한 이벤트가 아닙니다. 하지만 최신 웹 애플리케이션에서는 웹 페이지를 통해 사용자와 상호 작용하고 적시에 사용자 데이터를 저장해야 합니다. 이때 웹 페이지 닫기 이벤트는 매우 중요합니다.

  1. 웹 페이지 닫기 이벤트 사용 방법

JavaScript에서는 window 객체의 beforeunload 이벤트를 사용하여 웹 페이지 닫기 이벤트에 응답할 수 있습니다. 이 이벤트는 브라우저가 문서를 언로드하기 직전에 시작됩니다. beforeunload 이벤트에서는 일부 정리 작업을 수행하고 데이터를 저장하는 등의 작업을 수행할 수 있습니다.

다음은 beforeunload 이벤트의 기본 사용법입니다.

window.addEventListener('beforeunload', function(event) {
   event.preventDefault(); // 阻止默认行为
   event.returnValue = ''; // 设置returnValue,可以提示用户是否离开
});
로그인 후 복사

위 코드에서는 addEventListener() 메소드를 통해 window 객체에 beforeunload 이벤트를 추가했습니다. 이벤트 핸들러에서는 일부 정리 작업을 수행하고 브라우저의 기본 제거 동작을 방지할 수 있습니다.

때때로 양식에 입력한 정보와 같이 종료 이벤트에서 사용자가 입력한 데이터를 가져와야 하는 경우가 있습니다. 이때 onbeforeunload 이벤트를 사용할 수 있습니다.

window.onbeforeunload = function(event) {
   var message = '您输入的内容尚未保存,确定要退出吗?';
   event.returnValue = message; // 设置提示消息
   return message; // 返回提示消息,可以在一些浏览器中生效
};
로그인 후 복사

위 코드에서는 event.returnValue 속성을 설정하여 프롬프트 메시지를 설정하고, 일부 브라우저에서 적용되도록 동일한 프롬프트 메시지를 반환합니다.

  1. 실용 사례

다음은 웹 페이지 닫기 이벤트를 사용하여 사용자 경험을 향상시키는 방법을 보여주는 몇 가지 실제 사례입니다.

1) 양식 데이터 저장

사용자가 양식에 일부 정보를 입력할 때, 저장되지 않으면 이 정보가 손실됩니다. 웹 페이지가 닫힐 때 양식 데이터를 자동으로 저장할 수 있습니다. 예:

window.addEventListener('beforeunload', function() {
   var inputBox = document.getElementById('input-box');
   localStorage.setItem('user-input', inputBox.value);
});
로그인 후 복사

위 코드에서는 localStorage를 사용하여 양식 데이터를 저장합니다. beforeunload 이벤트에서는 입력 상자의 값을 가져와 로컬 저장소에 저장합니다.

2) 양식 데이터 제출

일부 특정 시나리오에서는 웹 페이지가 닫힐 때 서버로 데이터를 전송해야 할 수도 있습니다. 예를 들어, 사용자가 양식에 정보를 입력한 후 웹 페이지를 닫으면 데이터가 손실되므로 웹 페이지가 닫히기 전에 데이터를 제출할 수 있습니다. 예:

window.addEventListener('beforeunload', function() {
   var formObj = document.getElementById('my-form');
   formObj.submit();
});
로그인 후 복사

위 코드에서는 양식 개체의 submit() 메서드를 호출하여 양식 데이터를 제출합니다. 브라우저는 웹페이지가 닫히기 전에 자동으로 이 데이터를 서버에 보냅니다.

3) 캐시 데이터 지우기

웹 페이지에 사진과 동영상이 많이 포함되어 있으면 브라우저의 캐시가 많은 디스크 공간을 차지할 수 있습니다. 디스크 공간 사용량을 줄이기 위해 웹 페이지를 닫을 때 캐시 데이터를 지울 수 있습니다. 예:

window.addEventListener('beforeunload', function() {
   window.localStorage.clear();
   window.sessionStorage.clear();
   window.indexedDB.deleteDatabase('my-database');
});
로그인 후 복사

위 코드에서는 localStorage와 sessionStorage를 사용하여 웹 페이지 캐시 데이터를 저장합니다. beforeunload 이벤트에서는 clear() 메서드를 사용하여 이 데이터를 지웁니다. 또한 indexedDB.deleteDatabase() 메서드를 사용하여 인덱스 데이터베이스를 삭제합니다.

4) 사용자 종료 여부 감지

사용자가 웹 탐색 중에 안타깝게도 브라우저를 닫는 경우 일부 데이터가 손실될 수 있습니다. 이를 방지하기 위해 페이지가 닫힐 때 사용자가 정말로 종료를 원하는지 감지할 수 있습니다. 예:

window.addEventListener('beforeunload', function(event) {
   var message = '您输入的内容尚未保存,确定要退出吗?';
   event.returnValue = message;
   return message;
});

window.addEventListener('unload', function() {
   alert('您已经成功退出本网站!');
});
로그인 후 복사

위 코드에서는 beforeunload 이벤트에 프롬프트 메시지를 설정하고, unload 이벤트에서는 사용자에게 성공적으로 종료되었음을 알리는 메시지를 표시합니다. 동시에 일부 브라우저에서 적용될 수 있도록 동일한 프롬프트 메시지를 반환합니다.

  1. 요약

웹페이지 닫기 이벤트는 웹페이지가 닫히기 전에 특정 작업을 수행하는 데 도움이 될 수 있는 매우 중요한 이벤트입니다. JavaScript에서는 window 객체의 beforeunload 이벤트와 onbeforeunload 이벤트를 사용하여 웹 페이지 닫기 이벤트에 응답할 수 있습니다. 웹 페이지 닫기 이벤트의 사용을 마스터함으로써 사용자에게 보다 원활한 웹 페이지 상호 작용 경험을 제공할 수 있습니다.

이 글에서 소개한 사용 사례 외에도 웹 페이지 닫기 이벤트를 사용할 수 있는 다른 응용 시나리오가 많이 있으며 독자는 자신의 필요에 따라 유연하게 적용할 수 있습니다.

위 내용은 자바스크립트 웹페이지 닫기 이벤트에 대해 이야기해보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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