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

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

新規登録して質問してみよう
ただいま回答率
85.48%
イベントハンドラ

マウスのクリックなどの特定の事象(イベント)が発生した時に実行される処理のことをイベントハンドラと呼びます。

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

1574閲覧

スクロール中のみ要素を透過させる

TakehiroShinmyo

総合スコア16

イベントハンドラ

マウスのクリックなどの特定の事象(イベント)が発生した時に実行される処理のことをイベントハンドラと呼びます。

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2019/05/27 02:02

---### スクロールイベントによって、スクロール中のみ要素を透過させて、また元に戻すことを繰り返したい

現在サイト作成においてサイドバーをスクロール中に透過させてスクロールが止まったらまた表示させてを繰り返したいのですがうまく行きません。一応、スクロールを始めると透過はするのですが、そのあとはなにも起こりません。
ご存知の方お力添えをいただきたいと思っています。

発生している問題・エラーメッセージ

Uncaught TypeError: Cannot read property 'add' of undefined

該当のソースコード

html

1<div id="single" class="column-320 single-320"></div>

css

1.active{ 2 opacity:0.4; 3}

試したこと

jsで色々いじっていますがエラーではなぜか「add」が読めないというエラーが出てしまいます。
現在のjsは下記の通りになってます。

js

1var timeoutId = document.getElementById('single')2 window.addEventListener("scroll", function(){ 3 timeoputId.classList.add("active"); 4 5 clearTimeout(timeoutId)l; 6 7 timeoutId = setTimeout( function(){ 8 timeoutId.classList.remove("active"); 9}, 500); 10});

よろしくお願いいたします

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

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

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

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

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

guest

回答1

0

ベストアンサー

用途に合わせて変数を用意しましょう。
現状のコードではtimeoutIdという変数を要素の格納とタイムアウトIDの格納2つに使用しようとしています。
また、timeoputIdは書き間違いかと思います。

投稿2019/05/27 02:12

kei344

総合スコア69407

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

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

TakehiroShinmyo

2019/05/27 02:47

コメントいただきありがとうございました! おかげさまで無事に動くようになりました!ありがとうございます。 varに初期化を宣言するという機能があることを知らなかったため、今回のようなミスになってしまいました。 今回のご回答をいただいてからjsを var timeoutId var single = document.getElementById('single'); window.addEventListener("scroll", function(){ single.classList.add("active"); clearTimeout( timeoutId ); timeoutId = setTimeout( function() { single.classList.remove("active"); }, 500); }); としましたら正常に動作致しました。迅速なご回答ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問