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

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

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

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

Q&A

解決済

2回答

2868閲覧

JQueryのtbodyクローンの参照がうまくいかない

isacRu

総合スコア64

jQuery

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

0グッド

0クリップ

投稿2016/11/23 06:55

javascript

1$(function(){ 2 $('#add_subject').on('click',function(){ 3 var tbody=$(this).parents('table').first().find('tbody').first(); 4 var clone_tr=tbody.find('tr').first().clone(); 5 6 var max_data_id = 0; 7 tbody.find('button').each(function(){ 8 var id=parseInt($(this).data('id')); 9 if(id!==null && id>max_data_id) max_data_id=id; 10 }); 11 tbody.find('input').each(function(){ 12 var num=parseInt($(this).attr('name').match(/\[([0-9]+)\]/)[1]); 13 if(num!==null && num>max_data_id) max_data_id=num; 14 }); 15 tbody.find('textarea').each(function(){ 16 var num=parseInt($(this).attr('name').match(/\[([0-9]+)\]/)[1]); 17 if(num!==null && num>max_data_id) max_data_id=num; 18 }); 19 20 tbody.append(clone_tr); 21 console.log(clone_tr.find('div [id="minutesItemList[0].subject"]').val()); 22 clone_tr.find('div [id="minutesItemList[0].subject').attr('id','minutesItemList[' + max_data_id + '].subject'); 23 clone_tr.find('div').attr('id','minutesItemList[' + max_data_id + '].body'); 24 clone_tr.find('p').attr('id','subject'+max_data_id+'.error'); 25 clone_tr.find('p').attr('id','body'+max_data_id+'.error'); 26 27 clone_tr.find('input').attr('name','minutesItemList['+max_data_id+'].subject').val(""); 28 clone_tr.find('input').attr('id','minutesItemList'+max_data_id+'.subject'); 29 clone_tr.find('textarea').attr('name','minutesItemList['+max_data_id+'].body').text(""); 30 clone_tr.find('textarea').attr('id','minutesItemList'+max_data_id+'.body'); 31 clone_tr.find('button').attr('data-id',max_data_id+1); 32 }); 33});

tbodyの最初のtrタグのクローンのidやname要素を参照したいのですが、うまくいきません。

javascript

1console.log(clone_tr.find('div [id="minutesItemList[0].subject"]').val());

のようにtbodyの最初のtrタグのクローンのidを参照しようとしたのですが、undefined(定義されていない)エラーがでてしまい参照できません。typeしか参照できないような仕様になっているのでしょうか?どうしたら参照できるか、わかる方教えてください。
以上、よろしくお願い致します。

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

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

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

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

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

guest

回答2

0

ベストアンサー

jQueryのセレクタで、"["、"]"、"."は"\"でエスケープする必要があります。
また、セレクタにスペースを入れると子孫が対象となるので、idを持つdivを取得したい場合はスペースは不要です。

javascript

1 2clone_tr.find('div[id="minutesItemList\\[0\\]\\.subject"]') 3

投稿2016/11/23 08:24

attercop

総合スコア246

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

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

isacRu

2016/11/23 08:59

解決しました。ありがとうございます! エスケープしないといけないんですね。非常に勉強になりました。
guest

0

javascript

1clone_tr.find('div [id="minutesItemList[0].subject"]')

と書くと、clone_tr内の<div>内でid="minutesItemList[0].subject"(書いたそのままの値)を探すという意味になります。div自体のidを対象に検索をかけたいなら、div[id=...]のようにスペースなしにする必要があります(自分自身も間違えていました、すみません)。

あと、<div>value属性を持ちませんので、.val()は(仮に正しくdivを選べていても)undefinedにしかなりません。

投稿2016/11/23 07:22

編集2016/11/23 08:27
maisumakun

総合スコア145183

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

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

isacRu

2016/11/23 07:28

そのtbodyには<div id="minutesItemList[0].subject" class="form-group">とあるので、間違いないと思います。
isacRu

2016/11/23 07:30

また、clone_tr.find('#minutesItemList[0].subject')と書いてもうまくいきませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問