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

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

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

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

Q&A

解決済

2回答

1207閲覧

クラスを削除したいのですが、jQueryが動かなくて困っています。

tomarine

総合スコア10

jQuery

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

0グッド

0クリップ

投稿2016/04/27 05:06

###前提・実現したいこと
クラスを削除したいのですが、jQueryが動かなくて困っています。
コードが間違っているのでしょうか?

具体的にいうと、
flavor1というクラスがついた画像をクリックすることで、<section class="opera1 opera">からopera1というクラスを削除し、CSSで紐付いている背景画像を削除したいです。

先ほどこちらで質問させていただき、トリガー無しの状態でクラスを削除することに成功したのですが、トリガーをclickで設定すると動きません。

度々の質問で申し訳ございませんが、ご教授ください。

###HTML

HTML

1<!DOCTYPE html> 2<html> 3<head> 4<meta charset="UTF-8" /> 5<script type="text/javascript" src="js/jquery-1.11.0.min.js"></script> 6<script type="text/javascript"> 7$(".flavor1").click(function(){ 8 $('.opera').removeClass('opera1'); 9}); 10</script> 11</head> 12<body> 13 <section id="flavor"> 14 <div class="flavor_flavor"> 15 <img src="img/flavor_1.png" class="flavor1"> 16 <div class="flavor_name"> 17 <h5>オリジナル</h5> 18 </div> 19 </div> 20 </section> 21 22 <section class="opera1 opera"> 23 <div class="opera1_title"> 24 <img src="img/opera_fork.png" alt=""> 25 <h5>オペラハウス</h5> 26 <img src="img/opera_fork.png" alt=""> 27 </div> 28 </section> 29</body>

###CSS

CSS

1.opera1{ 2 background-image: url(../img/opera1_back.png); 3 background-size:cover; 4} 5

###試したこと
トリガーを設定しなければ、動作するので、トリガーがおかしいのでしょうか?

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

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

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

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

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

kei344

2016/04/27 05:52

「トリガー」とはどの部分のことを言うのでしょうか。質問文に追記いただけませんか?
guest

回答2

0

もしもclass="opera1"がjavaScriptの動的な処理によって要素内に追加されたとしても、 セレクタにマッチしていれば下記の.on(event)でその新しい要素に対してもイベントハンドラが有効になります。

javascript

1$(document).on("click", ".flavor1", function() { 2 $('.opera').removeClass('opera1'); 3}); 4

投稿2016/04/27 06:22

編集2016/04/27 06:24
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

tomarine

2016/04/27 06:36

ご回答ありがとうございます。 on要素はあとから追加された要素に対してもイベントをつけられるのですね! 参考になりました! 本当にありがとうございます!
guest

0

ベストアンサー

以下のようにするとどうですか?

javascript

1jQuery(function($) { 2 $(".flavor1").click(function(){ 3 $('.opera').removeClass('opera1'); 4 }); 5});

投稿2016/04/27 05:40

root_jp

総合スコア4666

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

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

tomarine

2016/04/27 06:35

こちらの方法で対処できました! ありがとうございました! 助かりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問