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

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

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

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

Q&A

解決済

2回答

851閲覧

マウスオーバーし、かつクリックされたら、関数を呼び出したい

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

0グッド

0クリップ

投稿2021/05/21 08:52

編集2021/05/21 08:55

前提

あるSNSサイトで、たとえば facebook のような「いいね!」機能を実装しようとしています。そこで、下のような手順を考えました

  1. いいね!ボタンにマウスポインターが乗ったら、時間を測り始める
  2. もし、ボタンがすぐにクリックされたら、「いいね!」をして、かつ、時間計測をやめる
  3. もし、すぐにボタンがクリックされずに、1秒経ったら、いくつかのリアクションのアイコンを表示し、かつ、時間計測をやめる
  4. ボタンからマウスポインターが外れたら、時間計測をやめる。このとき、もしリアクションアイコンが表示されていたら、それを閉じる

マウスポインターがある要素に乗ったら、時間を測りたいので、下のようにonmouseoverを書きました

html

1<button id="reaction" onmouseover="reaction()">Click this</button>

そして、下のような関数を書きました

javascript

1function reaction() { 2 3 const reaction = document.getElementById('reaction'); 4 reaction.addEventListener('click', console.log('Clicked')); 5 6}

ボタンにマウスポインターが乗り、かつ (その後1秒経つ前に) ボタンがクリックされたら、ある関数を呼び出したいので、こういう記述をしました。(ある関数というのは、上の記述ではconsole.log('Clicked')です)

課題

しかし、なぜかマウスポインターが乗ったとたんにそのある関数が呼び出されてしまいます。「マウスポインターが乗りさらにクリックされたら」という条件のもとで関数を呼び出すことはできますか?

ご意見やヒント、参考情報がございましたら、お寄せくださいませ

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

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

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

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

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

guest

回答2

0

ベストアンサー

js

1reaction.addEventListener('click', function () { console.log('Clicked'); } );

投稿2021/05/21 08:54

kei344

総合スコア69606

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

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

退会済みユーザー

退会済みユーザー

2021/05/21 09:01

とてもはやいご回答をありがとうございます。そして、課題をクリアすることができました。無名関数っていうんでしたっけ?調べてみます
guest

0

javascript

1<script> 2window.addEventListener('DOMContentLoaded', ()=>{ 3 const b=document.querySelector('#reaction'); 4 let timerId; 5 b.addEventListener('mouseover',e=>{ 6 console.log("start"); 7 timerId=setTimeout(()=>{ 8 console.log("end"); 9 timerId=null; 10 },1000); 11 }); 12 b.addEventListener('mouseout',e=>{ 13 if(timerId){ 14 console.log("stop"); 15 clearTimeout(timerId); 16 timerId=null; 17 } 18 }); 19 b.addEventListener('click',e=>{ 20 if(timerId){ 21 console.log("clicked"); 22 clearTimeout(timerId); 23 timerId=null; 24 } 25 }); 26}); 27</script> 28<button id="reaction">Click this</button>

投稿2021/05/21 09:26

yambejp

総合スコア116724

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

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

退会済みユーザー

退会済みユーザー

2021/05/21 10:32

ありがとうございます。勉強になります...!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問