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

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

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

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

jQuery

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

3回答

1718閲覧

タブ切り替え時に、特定のタブだけonClickが反応しない(CodePenにソースあります)

ksyunnnn

総合スコア60

JavaScript

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

jQuery

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2017/06/05 06:30

編集2017/06/05 06:31

###前提・実現したいこと

下記ソースにて、タブ切り替え時に特定のタブだけOnClickが反応しません(330行目)
https://codepen.io/ksyunnnn/pen/RgNrqb

jQueryでDOMを操作しHTMLを動的に変化させているので、その中に原因があるのでは、、と考えているのですが
原因の究明に至らず困惑しています。

###該当のソースコード

javascript

1// タブ切り替え 2$('#tabMonth > ul li').on('click', function() { 3 $(document.body).on('click', '#tabMonth > ul li', function() { 4 var cardId = $('#cardInfo select[name="cardList"]').val(); 5 var paymentId = $(this).attr('data-id'); 6 7 var dispData = getData(cardId, paymentId); 8 draw(dispData, cardId, paymentId); 9 10 var tabId = $(this).attr('data-tab'); 11 12 if (tabId == "t0") { 13 $('#siharai').show(); 14 $('#cardInfo').show(); 15 $('#cardInfo').addClass('col-sm-8'); 16 17 $('#siharai.remove').remove(); 18 } else if (tabId == "t1") { 19 $('#siharai').hide(); 20 $('#cardInfo').show(); 21 $('#cardInfo').removeClass('col-sm-8'); 22 $('#siharai.remove').remove(); 23 } else if (tabId == "t2") { 24 $('#siharai').show(); 25 $('#cardInfo').hide(); 26 27 $('#siharai.remove').remove(); 28 $('#siharai').clone(true).insertAfter('#siharai').addClass('remove add1'); 29 $('#siharai.add1').clone(true).insertAfter('#siharai.add1').addClass('remove add2').removeClass('add1'); 30 $('#siharai.add1 div.seikyu span').text(data.addInfo[0].price); 31 $('#siharai.add2 div.seikyu span').text(data.addInfo[1].price); 32 } else if (tabId == "t9") { 33 34 35 alert("これが動かない"); 36 37 38 } 39 });

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

ライブラリは下記を利用しています。

https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0-alpha.6/js/bootstrap.min.js

よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

ベストアンサー

理由:
支払い履歴をフィルタリングするときに、1けんもないばあいに止まる

// 以下のフィルタで、 t9 を選択した時に条件に合致する1件も支払い履歴がないので // var thisPayment = data.paymentInfo.filter(function(item, index) { if (item.relating_with_card == cardId && item.id == paymentId) { return true; } });
// のちの呼び出し以下の第一引数に紐づく // dispData.thisPayment // が未定義となり draw(dispData, cardId, paymentId);
// 未定義となりのthisPaymentのパラメタ yearを読むのでそこで泊まる。 $meisaiAt.text(dispData.thisPayment.year + "年 " + dispData.thisPayment.month + "月");

解決方法:
仕様に基づくのでわからないです。ただ、1件もない場合の処理の追加か、処理の見直しかと。

投稿2017/06/05 06:47

編集2017/06/05 06:49
kanimaru

総合スコア1013

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

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

ksyunnnn

2017/06/05 06:49

なるほど、、! 完全に自分の作ったロジックミスですね。。 確認します。ありがとうございます!
guest

0

関数の読み込みの順番を変更することで対処しました。

ご回答いただきありがとうございました!

投稿2017/06/05 06:56

ksyunnnn

総合スコア60

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

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

0

var tabId = $(this).attr('data-tab');
の下に
console.log(tabId)
とした時、ちゃんとt9をつかめていますか?

投稿2017/06/05 06:34

yambejp

総合スコア114843

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

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

ksyunnnn

2017/06/05 06:39

コメントありがとうございます。 確認したところ掴めていないようでした。
ksyunnnn

2017/06/05 06:41

そもそも .on('click'。。。 が反応していないようでした、、なぜなのでしょうか、、m(__)m
ksyunnnn

2017/06/05 06:47

連続でコメントすいません 上記嘘つきました。.on('click'。。。は反応していました。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問