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

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

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

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

Q&A

解決済

1回答

167閲覧

js(jQuery)がうまく動きません

gomatan1258

総合スコア67

JavaScript

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

0グッド

1クリップ

投稿2017/04/19 02:26

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}

javascript

1$(function(){ 2 var $selectedKoma = null; 3 4 $('.koma').on('click', function(){ 5 $selectedKoma = $(this); 6 console.log("選択されました。"); 7 }); 8 9 $('.masume:not(:has(.koma))').on('click', function(){ 10 console.log($selectedKoma); 11 $(this).append($selectedKoma); 12 $selectedKoma = null; 13 }); 14}); 15

イメージ説明

あるmasumeクラスの子要素のkomaクラスを別のmasumeクラスの子要素に移動させたいのですが、一回きりで移動しなくなってしまいます。console.logで確かめたところ、なぜか2回目から'.masume:not(:has(.koma))'まで選択されているようです。
何回も移動できるようにしたいので、やり方を教えてください。よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

この記述だと、「初期状態でkomaが入っていないmasume」にだけ効果が出ます。つまり、一度でもkomaが移動してしまうとこの判定はおかしくなってしまいます。

JavaScript

1$('.masume:not(:has(.koma))').on('click', function(){

こうすると、「動いた後でも」判定が正しく行われます。

JavaScript

1$(document).on('click','.masume:not(:has(.koma))', function(){

投稿2017/04/19 02:51

masaya_ohashi

総合スコア9206

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

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

gomatan1258

2017/04/19 03:08

ありがとうございました。大変勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問