質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

1回答

760閲覧

画面表示時のみ、かつブラウザが開かれていない場合にタブを閉じる方法について

mikikoji

総合スコア7

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2021/06/08 03:06

新規にタブを開いて画面を表示する際に、ブラウザが開かれていなければそのタブを閉じる実装を実現したいです。

windowClose = function () { document.addEventListener("visibilitychange", function() { if (document.visibilityState === 'hidden') { window.close(); } else { return false; } }); };        $(window).on("load", function() {         windowClose();        });

上記の実装で画面の非表示を検知してタブを閉じることはできるのですが、windowCloseがいつでも呼び出されてしまい「画面表示時のみ」という部分を実現できません。つまり、画面表示時にブラウザに滞在していれば以降はそのまま表示し続けて問題なく、画面表示された際に1度だけ処理が実行されるような実装がゴールです。
有効な実装方法があれば教えていただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2021/06/08 04:33

質問が全体的にわかりづらいです。 ・新規にタブを開いて画面を表示する→具体的にどうしていますか? ・ブラウザが開かれていなければ→どういう意味か説明してください ・そのタブを閉じる→ブラウザが開かれてないのに閉じるとは?
guest

回答1

0

visibilitychange が1回だけ発動できれば良い、ということでよろしいですか?

イベントリスナーはaddしたものをremoveすることもできます。
https://developer.mozilla.org/ja/docs/Web/API/EventTarget/removeEventListener

addとremoveで同じ関数オブジェクトを引数に入れる必要があるので、add時のコールバック関数を無名関数にするとremoveできません。変数に入れるか通常の関数として定義し、コールバック関数中の適切な箇所でremoveEventListenerすれば良いのではないかと思います。

※要件が問題文からよくわからないので検証はしていません。あしからず。

投稿2021/06/12 11:52

hope_mucci

総合スコア4447

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問