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

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

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

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

jQuery

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

Q&A

解決済

2回答

3221閲覧

【jQueryで神経衰弱を作成したい】1枚目と2枚目を比較しているときは、3枚目をクリックできないようにしたいです。

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2021/01/05 05:58

前提・実現したいこと

jQueryで神経衰弱を作成したいです。
内容はこういったことです。

①: 16枚のリストの中から "?" と書かれたものをひとつクリックする
②: その要素に書かれている "?" が "6" などの数字に変わる
③: もうひとつ"?"と書かれたものをクリックする
④: その要素に書かれている "?" が "6" などの数字に変わる
⑤: ②と④で表示された数字が一致している場合は、開いた数字はそのままで①に戻る。一致していない場合は1秒後に数字が "?" に戻り①にもどる。
⑥: 全ての要素が開かれたときにアラートで "Game Over"

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

2枚目のカードを開いた後に3枚目のカードをクリックするとカードが開いてしまいます。
1枚目と2枚目を比較しているときは、3枚目をクリックできないようにしたいです。

該当のソースコード

HTML <body> <ul class="lists clearfix"></ul> </body> CSS .lists { border: 10px #CCC solid; } .lists > li { float: left; width: 25%; background-color: #EEE; border-top: 2px #CCC solid; border-right: 2px #CCC solid; font-size: 20px; font-weight: bold; line-height: 75px; text-align: center; cursor: pointer; -webkit-box-sizing: border-box; box-sizing: border-box; } .lists > li:nth-child(-n + 4) { border-top: none; } .lists > li:nth-child(4n) { border-right: none; } jQuery <script> $(function () { var $lists = $(".lists"), totalCard = 16, // 合計枚数 arrayCards = [], // カードの数値を格納 firstCard = "", // 1枚目のカード secondCard = "", // 2枚目のカード isFirst = true; // 1枚目か判定 // カードの中身を作成 for (var i = 1; i <= totalCard / 2; i++) { arrayCards.push(i, i); } arrayCards // ランダムに並び替える .sort(function () { return Math.random() - Math.random(); }) // li要素を作成 .map(function (number) { return "<li class='close' data-number='" + number + "'>?</li>"; }) // ulにli要素を追加 .forEach(function (element) { $lists.append(element); }); // クリックしたときの処理 $lists.find("li").on("click", function () { // カードを開ける var openCard = $(this).css("pointer-events", "none").text($(this).data("number")); setTimeout(function () { // 1枚目の場合 if (isFirst) { firstCard = openCard; isFirst = false; // 2枚目の場合 } else { secondCard = openCard; // 1枚目と2枚目が同じ場合 if (firstCard.data("number") == secondCard.data("number")) { $(firstCard).removeClass("close"); $(secondCard).removeClass("close"); // 全部のカードが揃ったら if ($(".close").length == 0) { alert("Game Over"); } // 1枚目と2枚目が違う場合 } else { $(firstCard).css("pointer-events", "").text("?"); $(secondCard).css("pointer-events", "").text("?"); } isFirst = true; } }, 1000); }); }); </script>

試したこと

2枚目のカードを開いた後にpointer-events(none)を指定して3枚目をクリックできないように設定したが、1枚目と2枚目の比較後にも3枚目を開けなくなった。

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

jQueryを学んだばかりで、うまくお伝えできていないと思いますがよろしくお願いします。

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

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

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

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

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

guest

回答2

0

クリックしないようにする、というより、クリックしたときの処理で、2枚カードが開いてたらなにもしなくて戻る、ってのを実装すればいいかと。

投稿2021/01/05 06:00

編集2021/01/05 06:01
y_waiwai

総合スコア88042

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

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

退会済みユーザー

退会済みユーザー

2021/01/05 12:24

ご回答ありがとうございます。 試してみたいと思います。
guest

0

ベストアンサー

setTimeoutを1枚目と2枚目が違う場合に行うことで解決することができました。

投稿2021/01/07 02:07

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問