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

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

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

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

HTML

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

CSS

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

Q&A

解決済

2回答

1711閲覧

アコーディオン型のメニューにアイコンを設定したい

gomakichi

総合スコア17

jQuery

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2018/03/13 03:26

実現したいこと

http://php.o0o0.jp/article/jquery-multiaccordion
上記のサイトを参考にアコーディオンメニューを作成しています。

この手法で作成したアコーディオンメニューにページ内最下部のように開いた時と閉じた時でアイコンの向きを変更したいのですが
こちらのサイトにはその手法が載っておらず、困っておりました。

dlやdt、ddも用いていないためどうしたら良いか困っています。

よろしければご教授願います。

~~~~~省略~~~~~ <span>メニュー 1</span> <ul> <li>メニュー 1-1 <ul> <li>メニュー 1-1-1 <p>テキストテキストテキストテキスト</p> </li> <li>メニュー 1-1-2 <p>テキストテキストテキストテキスト</p> </li> </ul> </li> </ul> ~~~~~省略~~~~~ <script> $(function(){ $("#allow_change").on("click", function() { $(this).next().slideToggle("fast"); $(this).toggleClass("active"); }); }); </script>
CSS(他のサイトを参考に書いて見ましたがどう当てはめたらいいのかさっぱりです・・・) span img { background:url("画像のパス/~~.png") left center no-repeat; } span img.active { background:url("画像のパス/~~.png") left center no-repeat; }

CSSを書く際の参考にしたサイト
https://ku-su.com/%E3%80%90jquery%E3%80%91%E7%B0%A1%E5%8D%98%EF%BC%81jquery%E3%81%A7%E3%82%A2%E3%82%B3%E3%83%BC%E3%83%87%E3%82%A3%E3%82%AA%E3%83%B3%E3%83%91%E3%83%8D%E3%83%AB%E3%82%92%E5%AE%9F%E8%A3%85%E3%81%99/

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

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

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

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

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

guest

回答2

0

ベストアンサー

クラスのon/offで、画像を切り替えていますね
開発ツールで見て見てください。

css

1span:before { 2 padding: 0 8px 0 0; 3 vertical-align: middle; 4 content: url(../../img/bullet_arrow_right.png); 5} 6span.selected:before { 7 content: url(../../img/bullet_arrow_down.png); 8}

投稿2018/03/13 03:39

kszk311

総合スコア3404

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

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

gomakichi

2018/03/13 03:51

開発ツールで確認できたのですね! 無事、解決しました。ありがとうございました。
guest

0

メニューの中身を直接編集するのではなく「before」疑似要素セレクタを使って挿入するのが良いかと思います。

#allow_change h2::before { content:url(閉じた時の画像.png); } #allow_change h2.collapsed::before { content:url(開いた時の画像.png); }

※「:before」でも「::before」でも動作しますが、css3では「::before」が推奨されています。

詳細は以下をご覧ください。
https://developer.mozilla.org/ja/docs/Web/CSS/::before

投稿2018/03/13 03:44

編集2018/03/13 03:52
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問