suchen
HeimWeb-FrontendHTML-TutorialWie unterscheidet ich zwischen dem Schließen eines Browser -Registerkartens und dem Schließen des gesamten Browsers mit JavaScript?

Wie unterscheidet ich zwischen dem Schließen eines Browser -Registerkartens und dem Schließen des gesamten Browsers mit JavaScript?

JavaScript unterscheidet das Schließen des Browser -Registerkartens und das vollständige Schließen des Browsers

Bei der täglichen Verwendung von Multi-Tabs-Browsen müssen Benutzer möglicherweise eine einzelne Registerkarte oder den gesamten Browser schließen. In einigen Anwendungsszenarien ist beispielsweise eine bestimmte Aktion erforderlich, wenn der Browser vollständig geschlossen ist (z. B. Löschen von Anmeldeinformationen), jedoch nicht beim Schließen einer einzigen Registerkarte. In diesem Artikel wird untersucht, wie JavaScript verwendet wird, um zwischen diesen beiden Situationen zu unterscheiden und entsprechende Lösungen zu liefern.

Problembeschreibung

Angenommen, die Webanwendung, die wir entwickelt haben, läuft im Chrome -Browser im Windows -System. Die Anforderung besteht darin, die Anmeldeinformationen zu löschen, wenn der Benutzer den gesamten Browser schließt, während die Anmeldeinformationen beim Schließen einer einzigen Registerkarte unverändert bleiben. Wie implementiere ich diese Funktion?

Lösung

Wir können das sessionStorage -Objekt von HTML5 verwenden, um dieses Problem zu lösen. Mit sessionStorage können Schlüsselwertpaardaten in derselben Sitzung gespeichert werden. Beim Schließen des Browsers werden die Daten in sessionStorage gelöscht, während das Schließen einer einzigen Registerkarte die sessionStorage -Daten anderer Registerkarten nicht beeinflusst.

Die spezifischen Implementierungsschritte sind wie folgt:

  1. Hören Sie sich das Browser Close -Ereignis an: Verwenden Sie das beforeunload -Ereignis, um den Browser -Schließ oder die Registerkarte Schließung anzuhören.

     window.adDeVentListener ('voranladung', Funktion (e) {
         // Code hinzufügen, um Anmeldeinformationen hier zu löschen, aber es ist zu beachten, dass die direkte Ausführung auch beim Schließen der Registerkarte auch zum Löschen führen kann.
     });
  2. Verwenden Sie SessionStorage, um das Schließverhalten zu unterscheiden: Wenn jede Registerkarte geladen wird, legen Sie ein sessionStorage -Element fest und überprüfen Sie, ob das Element bei der Schließung vorhanden ist. Wenn es existiert, bedeutet dies, dass die Registerkartenseite geschlossen ist. Wenn es nicht existiert, bedeutet dies, dass der gesamte Browser geschlossen ist.

     // SessionStorage festlegen, wenn die Seite geladen wird
     window.addeventListener ('laden', function () {
         SessionStorage.SetItem ('tabopen', 'true');
     });
    
     // SessionStorage überprüfen, wenn sie geschlossen sind
     window.adDeVentListener ('voranladung', Funktion (e) {
         if (! sessionStorage.getItem ('tabopen')) {
             // Anmeldeinformationen ClearLogininfo ();
         } anders {
             // SessionStorage item SessionStorage.removeItem ('tabopen') entfernen;
         }
     });
    
     Funktion clearLogininfo () {
         // Fügen Sie den Code hinzu, um die Anmeldeinformationen hier zu Console.log zu löschen ('Löschen von Anmeldeinformationen ...');
     }

Durch die obige Methode können wir effektiv zwischen dem Schließen der Registerkartenseite und dem Schließen des Browsers unterscheiden und den Betrieb der Löschung der Anmeldeinformationen durch vollständig geschlossene Browser durchführen, während dieser Vorgang beim Schließen einer einzelnen Registerkartenseite nicht durchgeführt wird. Es ist zu beachten, dass das beforeunload Ereignis vom Browser abhängig von der spezifischen Implementierung der Browser- und Benutzereinstellungen abgefangen oder verzögert werden kann. Um die Zuverlässigkeit zu verbessern, können andere Technologien wie das serverseitige Sitzungsmanagement berücksichtigt werden.

Das obige ist der detaillierte Inhalt vonWie unterscheidet ich zwischen dem Schließen eines Browser -Registerkartens und dem Schließen des gesamten Browsers mit JavaScript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
c盘的users是什么文件夹?可以删除吗?c盘的users是什么文件夹?可以删除吗?Nov 10, 2022 pm 06:20 PM

c盘的users是用户文件夹,主要存放用户的各项配置文件。users文件夹是windows系统的重要文件夹,不能随意删除;它保存了很多用户信息,一旦删除会造成数据丢失,严重的话会导致系统无法启动。

微软的pin码是什么微软的pin码是什么Oct 14, 2022 pm 03:16 PM

PIN码是Windows系统为了方便用户本地登录而独立于window账户密码的快捷登录密码,是Windows系统新添加的一套本地密码策略;在用户登陆了Microsoft账户后就可以设置PIN来代替账户密码,不仅提高安全性,而且也可以让很多和账户相关的操作变得更加方便。PIN码只能通过本机登录,无法远程使用,所以不用担心PIN码被盗。

启动任务管理器的三个快捷键是什么启动任务管理器的三个快捷键是什么Sep 21, 2022 pm 02:47 PM

启动任务管理器的三个快捷键是:1、“Ctrl+Shift+Esc”,可直接打开任务管理器;2、“Ctrl+Alt+Delete”,会进入“安全选项”的锁定界面,选择“任务管理器”,即可以打开任务管理器;3、“Win+R”,会打开“运行”窗口,输入“taskmgr”命令,点击“确定”即可调出任务管理器。

window下报错“php不是内部或外部命令”怎么解决window下报错“php不是内部或外部命令”怎么解决Mar 23, 2023 pm 02:11 PM

对于刚刚开始使用PHP的用户来说,如果在Windows操作系统中遇到了“php不是内部或外部命令”的问题,可能会感到困惑。这个错误通常是由于系统无法识别PHP的路径导致的。在本文中,我将为您提供一些可能会导致这个问题的原因和解决方法,以帮助您快速解决这个问题。

windows操作系统的特点包括什么windows操作系统的特点包括什么Sep 28, 2020 pm 12:02 PM

windows操作系统的特点包括:1、图形界面;直观高效的面向对象的图形用户界面,易学易用。2、多任务;允许用户同时运行多个应用程序,或在一个程序中同时做几件事情。3、即插即用。4、出色的多媒体功能。5、对内存的自动化管理。

win10自带的onenote是啥版本win10自带的onenote是啥版本Sep 09, 2022 am 10:56 AM

win10自带的onenote是UWP版本;onenote是一套用于自由形式的信息获取以及多用户协作工具,而UWP版本是“Universal Windows Platform”的简称,表示windows通用应用平台,不是为特定的终端设计的,而是针对使用windows系统的各种平台。

win10为什么没有“扫雷”游戏了win10为什么没有“扫雷”游戏了Aug 17, 2022 pm 03:37 PM

因为win10系统是不自带扫雷游戏的,需要用户自行手动安装。安装步骤:1、点击打开“开始菜单”;2、在打开的菜单中,找到“Microsoft Store”应用商店,并点击进入;3、在应用商店主页的搜索框中,搜索“minesweeper”;4、在搜索结果中,点击选择需要下载的“扫雷”游戏;5、点击“获取”按钮,等待获取完毕后自动完成安装游戏即可。

在windows中鼠标指针呈四箭头时一般表示什么在windows中鼠标指针呈四箭头时一般表示什么Dec 17, 2020 am 11:39 AM

在windows中鼠标指针呈四箭头时一般表示选中对象可以上、下、左、右移动。在Windows中鼠标指针首次用不同的指针来表示不同的状态,如系统忙、移动中、拖放中;在Windows中使用的鼠标指针文件还被称为“光标文件”或“动态光标文件”。

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor