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

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

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

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

jQuery

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

Q&A

解決済

2回答

1070閲覧

前回の続きでjQueryでの質問です

gomatan1258

総合スコア67

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2017/04/20 07:18

html

1<!DOCTYPE html> 2<html> 3<head> 4<meta charset="UTF-8"> 5<link rel="stylesheet" href="../css/test.css"> 6<title>Test</title> 7</head> 8<body> 9<div class="masume"></div> 10<div class="masume"></div> 11<div class="masume"></div> 12<div class="masume"><p class="koma"></p></div> 13<div class="masume"></div> 14<div class="masume"></div> 15<div class="masume"></div> 16<div class="masume"><p class="koma"></p></div> 17<div class="masume"></div> 18 19<script src="https://code.jquery.com/jquery-3.1.0.min.js"></script> 20<script src="../js/test.js"></script> 21</body> 22</html>

css

1html body { 2 margin: 0; 3} 4.masume { 5 float: left; 6 width: 28px; 7 height: 28px; 8 border: solid 1px #000; 9} 10 11.koma { 12 clear: left; 13 background-color: blue; 14 width: 28px; 15 height: 28px; 16 margin: 0; 17} 18

javascript

1$(function(){ 2 var $selectedKoma = null; 3 //駒をクリックして選択する 4 $('.koma').on('click', function(e){ 5 $selectedKoma = $(this); 6 $selectedKoma.css('background-color', 'yellow').addClass("droppable"); 7 console.log("選択されました。"); 8 }); 9 //駒が選択状態のときに駒がない升目をクリックすると駒が移動して選択解除する 10 $(document).on('click', '.masume:not(:has(.koma))', function(){ 11 //$selectedKoma.css('background-color', 'blue'); 12 if($('.droppable').length > 0) { 13 $(this).append($selectedKoma); 14 console.log("選択解除しました。"); 15 $selectedKoma.css('background-color', 'blue').removeClass("droppable"); 16 $selectedKoma = null; 17 } 18 }); 19 //駒が選択状態のときに升目以外のところをクリックすると選択解除する 20 $(document).on('click', function(e){ 21 if(!$(e.target).closest('.masume').length) { 22 if($('.droppable').length > 0) { 23 $selectedKoma.css('background-color', 'blue').removeClass("droppable"); 24 console.log("選択解除しました。"); 25 $selectedKoma = null; 26 } 27 } 28 }); 29 //選択状態以外の駒をクリックするとconsole.logでテストと出力する 30 if($selectedKoma != null) { 31 $(document).on('click', '.koma:not('+$selectedKoma+')', function(){ 32 console.log("テスト"); 33 }); 34 } 35}); 36

いつもお世話になっています。前回の質問で最後の、'.koma:not('+$selectedKoma+')' の $selectedKoma がnullということで上手く動かないのがわかりました。色々考えたのですが、どうしてもコメントの 選択状態以外の駒をクリックするとconsole.logでテストと出力する のやり方がわかりません。どうやって出力すればいいでしょうか?よろしくお願いします。

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

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

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

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

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

guest

回答2

0

これで想定している動作になるのでは。

javascript

1if($selectedKoma != null) { 2 $(document).on('click', '.koma:not('+$selectedKoma+')', function(){ 3 console.log("テスト"); 4 }); 5}

javascript

1$(document).on('click', '.koma.droppable', function(){ 2 console.log("テスト"); 3});

イベントのバブリングは.komaの方がdocumentよりも早いため、未選択のコマをクリックした時はdroppableクラスがついているはずです。それを利用しています。

訂正

と思ったのですが、これだとダメですね……
こうですね。

javascript

1$('.koma').on('click', function(e){ 2 $selectedKoma = $(this); 3 $selectedKoma.css('background-color', 'yellow').addClass("droppable"); 4 console.log("選択されました。"); 5});

javascript

1$('.koma').on('click', function(e){ 2 $selectedKoma = $(this); 3 if (!$selectedKoma.hasClass('droppable')) console.log("テスト"); 4 $selectedKoma.css('background-color', 'yellow').addClass("droppable"); 5 console.log("選択されました。"); 6});

投稿2017/04/20 09:27

編集2017/04/20 09:38
Lhankor_Mhy

総合スコア35871

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

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

Lhankor_Mhy

2017/04/20 09:29

あ、そうか、それじゃダメか…… もう少し考えてみます。
gomatan1258

2017/04/21 05:36

上手く動かなかったですが、すごく参考になりました。ありがとうございます。
guest

0

自己解決

javascript

1$(function(){ 2 var $selectedKoma = null; 3 //駒をクリックして選択する 4 $('.koma').on('click', function(){ 5 $selectedKoma = $(this); 6 if ($selectedKoma.hasClass('droppable')) { 7 $selectedKoma.css('background-color', 'blue').removeClass("droppable"); 8 console.log("選択解除しました。"); 9 }else { 10 $selectedKoma.css('background-color', 'yellow').addClass("droppable"); 11 if($('.droppable').length > 1) { 12 $('.koma').css('background-color', 'blue').removeClass("droppable"); 13 $selectedKoma.css('background-color', 'yellow').addClass("droppable"); 14 } 15 console.log("選択されました。"); 16 } 17 }); 18 //駒が選択状態のときに駒がない升目をクリックすると駒が移動して選択解除する 19 $(document).on('click', '.masume:not(:has(.koma))', function(){ 20 //$selectedKoma.css('background-color', 'blue'); 21 if($('.droppable').length > 0) { 22 $(this).append($selectedKoma); 23 console.log("選択解除しました。"); 24 $selectedKoma.css('background-color', 'blue').removeClass("droppable"); 25 $selectedKoma = null; 26 } 27 }); 28 //駒が選択状態のときに升目以外のところをクリックすると選択解除する 29 $(document).on('click', function(e){ 30 if(!$(e.target).closest('.masume').length) { 31 if($('.droppable').length > 0) { 32 $selectedKoma.css('background-color', 'blue').removeClass("droppable"); 33 console.log("選択解除しました。"); 34 $selectedKoma = null; 35 } 36 } 37 }); 38}); 39

自分が現在作りたかったものができました。皆様ありがとうございます。

投稿2017/04/21 05:35

gomatan1258

総合スコア67

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問