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

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

ただいまの
回答率

90.54%

  • JavaScript

    16337questions

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

  • jQuery

    6672questions

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

一度でもクリックされていたら実行しないという処理の方法を知りたいです

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 631

hiro421

score 57

下記のように10秒経つと擬似的にaタグをクリックさせて自動でモーダルを開かせるようにしているのですが、こちらを
10秒経つ前に一度でもクリックさせたら自動で開くという処理を停止させたいのですが、この場合どのようにjsを書けばいいのでしょうか。。
あまり詳しくなく、アドバイスいただけると助かります。
よろしくお願いいたします。

モーダルは下記を使用しています。
http://dimsemenov.com/plugins/magnific-popup/

<a href="https://www.youtube.com/watch?v=xxx" class="popup"><img src="img/pic_movie.jpg" alt=""/></a>
$(function(){
$('a.popup').magnificPopup({
fixedContentPos: false,
preloader: false,
type: 'iframe'
});

a();
function a(){
    $('a').on("click", function(){});
    setTimeout(function(){
        $('a').trigger("click");
    },10000);
}

});
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

clearTimeout を使えばキャンセル可能です。

【setTimeoutの削除【JavaScript】 - あぷすた】
http://appstars.jp/archive/714

【window.clearTimeout - Web API インターフェイス | MDN】
https://developer.mozilla.org/ja/docs/Web/API/WindowTimers/clearTimeout


追記:

書かれている下記記述で問題ないと思いますよ。

var timer;

timer = setTimeout( function() {
    $( 'a' ).trigger( 'click' );
}, 3000 );

$( 'a' ).on( 'click' , function(){
    clearTimeout( timer );
} );

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/30 15:59

    ありがとうございます!
    ただうまくいかず、、

    $('a').on("click", function(){
    if(!timer) {
    timer = setTimeout(function(){
    $('a').trigger("click");
    timer = null;
    }, 10000);
    }
    });

    どのように書けばいいのでしょうか。。

    キャンセル

  • 2017/03/30 16:39

    書かれたコードのsetTimeoutはクリックした際に開始します。その挙動を望まれているのでしょうか?

    キャンセル

  • 2017/03/30 16:50

    いえ、無知ですみません。。

    $('a').on("click", function(){});
    var timer;
    timer = setTimeout(function(){
    $('a').trigger("click");
    }, 3000);
    $('a').on("click", function(){
    clearTimeout(timer);
    });

    このような感じ書いたら上手く動いている気がするんですが、合ってますでしょうか。。?

    キャンセル

  • 2017/03/30 16:51

    一応これで、3秒後にモーダルが開いて、3秒以内にクリックしたら自動でモーダルが開かないというのは実現できました。。

    キャンセル

  • 2017/03/30 17:14

    ちょっと気になったので横から失礼。
    おそらくあなたは「aタグをクリックしたときに何も実行しないようにする」という意図で「$('a').on("click", function(){});」というコードを書いているのだと思います。しかし「on」はイベント時に実行する処理を『追加』するので、意図した処理は行えていません。
    イベント時の処理を解除するには「off」を利用しましょう。

    キャンセル

  • 2017/03/30 17:15

    aをクリックしたらタイマーが走り出すのですか?

    キャンセル

  • 2017/03/30 17:25

    色々すみません。。
    やりたい事は3秒後にモーダルを開くためのボタンを擬似的に(triggerで)クリックさせてます。
    ただ3秒以内にボタンをクリックすると、自動でモーダルが開く処理は停止させたいというのが
    希望です。

    $('a').on("click", function(){});
    これを入れたのは、triggerを使うのに必要なのかなと思ったからです。。

    キャンセル

  • 2017/03/30 18:22

    なんの3秒後(10秒後?)なのか書かないと発火させられないですよね
    そこで、aをクリックしたらタイマーが走りだすとして、そのクリックで
    タイマーをとめるのだとおかしいような気がします

    キャンセル

  • 2017/03/30 18:24

    To: yambejpさん
    多分ですが、ページを表示してから10秒ということではないでしょうか。

    キャンセル

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

  • ただいまの回答率 90.54%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • JavaScript

    16337questions

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

  • jQuery

    6672questions

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