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

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

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

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

Q&A

3回答

538閲覧

jqueryでボタンのクラスを切替るとクリックイベントが起きない

avantgarden

総合スコア121

jQuery

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

0グッド

0クリップ

投稿2018/06/20 02:43

編集2018/06/20 02:55

HTMLで「hide_button」というクラスがついているボタンに対して、
特定の要素(「hide」というクラスの要素)を隠し、同時にクラスを
切り替えて、再度ボタンクリックで要素を表示させる、ということを
したいのですが、クラス切替後にボタンをクリックしてもイベントが
置きません。

JSのコードは下記のとおりで、クラス切り替え後にボタンをクリックしても
何も起きないので、ためしにalertを出そうとしても出ない状態です。

<!-- ボタン画像 --> <img src="img/button.jpg" class="hide_button"> <script type="text/javascript"> $(function() { $('.hide_button').click(function() { $('.hide').hide(); $(this).css('opacity', '0.5').removeClass('hide_button').addClass('show_button'); }); $('.show_button').click(function() { alert('test'); }); }); </script>

誤植等はないと思うので、何がおかしいのか教えていただきたいです。

よろしくお願いします。

【追記】
ボタンのHTMLを追記しました。
このボタンのクラスを切り替えて、クラスによって別のイベントを起こそうとしています。

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

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

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

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

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

m.ts10806

2018/06/20 02:50

htmlもご提示ください。
guest

回答3

0

動的要素(つまりスクリプトにより現れたり消えたりするもの)にイベントを付与する場合はdocumentなどからイベントを付与する必要があります。

js

1$(document).on("click",".show_button",function(){ 2 alert("show"); 3});

投稿2018/06/20 03:00

m.ts10806

総合スコア80850

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

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

0

普通にclick()でイベントリスナーが登録される要素は
click()が実行された時にそのセレクタに引っかかったもの

click()が実行されるより後にそのセレクタに引っかかるようになったものは対象外

それをやりたい場合は例えば

js

1$('form').on('click','.show_button',function(){ 2 alert('test'); 3});

みたいな感じに

これでform要素の子孫要素がクリックされた時
クリックされた要素が.show_buttonに引っかかるものだった時に
イベントリスナー実行というようになる

投稿2018/06/20 02:51

編集2018/06/20 02:53
KazuhiroHatano

総合スコア7804

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

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

0

「.show_button」に対してclickイベントを設定するときに、「.show_button」を持つエレメントが無いからだと思います。

投稿2018/06/20 02:50

yuusuko

総合スコア145

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問