🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

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

HTML

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

CSS

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

Q&A

解決済

1回答

1615閲覧

Xがハンバーガーメニューに戻らない

Matsunosuke

総合スコア6

JavaScript

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2019/10/02 05:21

編集2019/10/03 11:01

:focusを用いてハンバーガーメニューをXにし、メニューが開くようにはできたのですが、Xを押すとハンバーガーメニューに戻り、メニューが閉じるようにするにはどうすればいいのでしょうか?

html

1<a id="nav-toggle" class="nav_slide_button" href="#"> 2 <span></span> 3 </a> 4 5 6 7

css

1#nav-toggle span, #nav-toggle span::before, #nav-toggle span::after { 2 cursor: pointer; 3 border-radius: 1px; 4 -moz-border-radius: 1px; 5 -webkit-border-radius: 1px; 6 -o-border-radius: 1px; 7 height: 3px; 8 width: 35px; 9 background: #fff; 10 position: absolute; 11 display: block; 12 content: ''; 13 -webkit-transition: all 500ms ease-in-out; 14 transition: all 500ms ease-in-out; 15} 16 17 18#nav-toggle span, #nav-toggle span::before, #nav-toggle span::after { 19 cursor: pointer; 20 border-radius: 1px; 21 -moz-border-radius: 1px; 22 -webkit-border-radius: 1px; 23 -o-border-radius: 1px; 24 height: 3px; 25 width: 35px; 26 background: #fff; 27 position: absolute; 28 display: block; 29 content: ''; 30 -webkit-transition: all 500ms ease-in-out; 31 transition: all 500ms ease-in-out; 32} 33#nav-toggle:focus span { 34 background-color: transparent; 35} 36#nav-toggle:focus span:before { 37 transform: rotate(45deg); 38 -webkit-transform: rotate(45deg); 39 -ms-transform: rotate(45deg); 40} 41#nav-toggle:focus span:before{ 42 top: 0; 43} 44#nav-toggle:focus span:after { 45 top:0; 46} 47#nav-toggle:focus span:after { 48 transform: translateY(-10px) rotate(-45deg); 49 -webkit-transform: translateY(-10px) rotate(-45deg); 50 -ms-transform: translateY(-10px) rotate(-45deg); 51 top: 10px; 52}

Javascript

1$(function() { 2 3 $('.nav_slide_button').click(function() { 4 $('nav').slideToggle(); 5 }); 6 7 8 9});

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

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

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

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

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

kyoya0819

2019/10/02 05:22

とりあえず質問は編集できるのでコードを追記してください。
kyoya0819

2019/10/02 05:32

マークダウン文法をご利用ください。
guest

回答1

0

ベストアンサー

使うなら :focus ではないでしょうか?
https://developer.mozilla.org/ja/docs/Web/CSS/:focus

投稿2019/10/03 07:00

x_x

総合スコア13749

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

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

Matsunosuke

2019/10/03 10:55

https://www.nxworld.net/tips/12-css-hamburger-menu-active-effect.html ご回答ありがとうございます。focusを用いて、クリックを押すとXとなり、メニューが開くようになったのですが、Xを押すと、このサイトのようにハンバーガーメニューに戻りません。 何か解決方法があればアドバイスよろしくお願いします
x_x

2019/10/04 04:30

質問は「ハンバーガーメニューがXにならない」でしたが変わったのでしょうか? :focus のままで閉じるのはトリッキーな方法になってしまうので、classの変更など別の方法をとることをお勧めします
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問