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

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

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

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

jQuery

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

Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

HTML

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

CSS

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

Q&A

解決済

1回答

1034閲覧

ハンバーガーメニューのアニメーションが動かない

kdh

総合スコア26

JavaScript

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

jQuery

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

Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/05/11 04:36

######ハンバーガーメニューをクリックしたときにクラスを追加してアニメーションするようなコードを書いているのですが、うまく作動しません。検証ツールで確認しましたが、activeのクラスは付けれていることから、jQueryの方は問題ないかと思います。スペルミスなども無いようにに感じるのですが、どこか違うとこはありますでしょうか?

html

1<div class="btn"> 2 <button class="btn__header"> 3 <span></span> 4 <span></span> 5 <span></span> 6 </button> 7</div>

css

1.btn{ 2 z-index: 100; 3 display: flex; 4 align-items: center; 5 6 &__header{ 7 background-color: transparent; 8 border: none; 9 outline: none !important; 10 cursor: pointer; 11 12 & > span{ 13 background-color:white; 14 width: 35px; 15 height: 3px; 16 display: block; 17 margin-bottom: 5px; 18 transition: transform 0.7s; 19 } 20 & :last-child{ 21 margin-bottom: 0; 22 } 23 } 24} 25 26.active{ 27 & .btn__header{ 28 & > span { 29 &:nth-child(1) { 30 transition-delay: 70ms; 31 transform: translateY(11px) rotate(135deg); 32 } 33 &:nth-child(2) { 34 transition-delay: 0s; 35 transform: translateX(-18px) scaleX(0); 36 } 37 &:nth-child(3) { 38 transition-delay: 140ms; 39 transform: translateY(-11px) rotate(-135deg); 40 } 41 } 42 } 43 }

jquery

1$('.btn').click(function(){ 2 $('.btn__header').toggleClass('active'); 3});

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

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

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

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

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

Lhankor_Mhy

2021/05/11 04:54

「うまく作動しません」とは、具体的には何が起きていますか? もし、「メニューが表示されない」というようなことでしたら、ご提示のコードにメニューが含まれていないので、こちらでは確認することができません。
Lhankor_Mhy

2021/05/11 04:58 編集

あ、ハンバーガーメニューのアイコンがアニメーションしない、ということか……
guest

回答1

0

ベストアンサー

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

scss

1.active{ 2// & .btn__header{ 3 &.btn__header{

投稿2021/05/11 04:57

Lhankor_Mhy

総合スコア36960

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

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

kdh

2021/05/11 05:03

動きました!ありがとうございます。 &の後のクラス名にはスペースを入れるものだと思っていました。 ここにはスペースを入れてはいけない規則などはあるのでしょうか?
Lhankor_Mhy

2021/05/11 05:20

& を接頭辞として使う場合、スペースは必要ないです。 .hoge{ &_fuga{} } は .hoge_fuga{} とコンパイルされますが、 .hoge{ & _fuga{} } は .hoge _fuga{} とコンパイルされます。 つまり、コンパイル後にスペースが不要な場合は、SCSSにもスペースを入れてはいけません。
kdh

2021/05/11 15:30

新しい知見でした!ありがとうございます。
Lhankor_Mhy

2021/05/12 00:34

お役に立てたようで何よりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問