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

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

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

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

Q&A

解決済

1回答

541閲覧

JavaScriptでCSSスタイル付与の際に先にAlertが読み込まれてしまう

moimoi_sushi

総合スコア26

JavaScript

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

0グッド

2クリップ

投稿2020/04/05 04:52

編集2020/04/05 05:22

前提・実現したいこと

ある特定サイトが開かれた際にblurをかけた後にalertを表示するプログラムを作りたいです。
しかしblurより先にalertが表示されてしまいます。
環境はGoogle Chrome (バージョン 80.0.3987.106(Official Build) (64 ビット) )になります。アドオンを作る目的です。

該当のソースコード

JavaScript

1if(isTargetUrl) { 2 const body = document.querySelector("body"); 3 body.style.filter = 'blur(6px)'; 4 alert('この時間帯は禁止されています'); 5}

試したこと

非同期処理やif(body.style.filter)をかませて見たりしましたが先にalertが表示されてしまいます。

補足情報(FW/ツールのバージョンなど)

alertを使わずにメッセージ子要素をbodyに付与する形で表記しても良いのですがそのままにするのも気持ち悪いのでどなたかご教授をお願いしたいです。

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

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

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

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

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

Lhankor_Mhy

2020/04/06 10:18

当方の環境(Firefox)では再現しなかったので、Chrome で試したところ、再現できました。 どうやら環境依存の問題の様ですね。 JavaScriptがCSSレンダリングをブロックしているのではないでしょうか。
hoshi-takanori

2020/04/06 20:26

適当にタイムアウトをかけてあげれば良いのでは。 setTimeout(function(){ alert('この時間帯は禁止されています'); }, 100);
moimoi_sushi

2020/04/08 06:50

@Lhankor_Mhy >JavaScriptがCSSレンダリングをブロックしているのではないでしょうか。 なるほど、JavaScript > CSSの優先順位?ということでしょうか。 >hoshi-takanori setTimeout(() => { alert('この時間帯は禁止されています'); }, 1);にしてもいけました。ありがとうございます。ちょっと気持ち悪い感じもするのでalertを使うかどうか検討してみたいと思います。
guest

回答1

0

自己解決

setTimeout(() => { alert('この時間帯は禁止されています'); }, 1);
でできました。
根本解決したとは言えませんが、環境の問題なようです。ありがとうございました。

投稿2020/04/08 06:51

moimoi_sushi

総合スコア26

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問