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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

jQuery

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

HTML

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

CSS

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

Q&A

解決済

2回答

1220閲覧

jqueryでtoggleが上手く実装できません。

katusi

総合スコア12

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

jQuery

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/02/12 22:29

html

<!DOCTYPE html> <html lang="ja"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="practice9.css"> <script src="https://tsukigime-rider.com/js/jquery-3.1.1.min.js"></script> <script src="https://tsukigime-rider.com/js/jquery-ui.js"></script> <script src="https://tsukigime-rider.com/js/public/plugin/jquery.ui.touch-punch.min.js"></script> <script src="https://tsukigime-rider.com/js/plugins/aos/aos.min.js"></script> <script src="https://tsukigime-rider.com/js/plugins/magnific-popup/jquery.magnific-popup.min.js"></script> <script src="https://tsukigime-rider.com/js/plugins/slick/slick.min.js"></script> <title>practice8</title> </head> <body> <header> <div class="inner"> <div class="menu-btn"><img src="http://bunkai-san.jp/wp-content/themes/bunkaisan/img/sp-menu.png" alt=""></div> <div class="menu-btn-close"><img src="http://bunkai-san.jp/wp-content/themes/bunkaisan/images/toggle-off.png" alt=""></div> <ul class="header-menu"> <li class="menu-btn01">CONCEPT</li> <li class="menu-btn02">FLOOR GUIDE</li> <li class="menu-btn03">NEWS</li> <li class="menu-btn04">ACCESS INFO</li> <li class="menu-btn05">CONTACT</li> </ul> <div class="header-logo"><a href="http://bunkai-san.jp/"><img src="http://bunkai-san.jp/wp-content/themes/bunkaisan/img/logo.png" alt=""></a></div> </div> </header>

css
.inner {
width: 100%;
overflow: hidden;
}
.inner ul {
list-style: none;
}
.header-menu {
display: flex;
justify-content: center;
position: relative;
top: -50px;
}
.header-menu li {
font-family: 'Abel', sans-serif;
margin: 20px;

}
.menu-btn img {
position: relative;
left: 1340px;
top: 20px;
}
.menu-btn-close img {
position: relative;
left: 1340px;
top: -40px;
width: 50px;
height: 50px;
display: none;
}

jQuery

<script> $(function() { $(".header-menu").css("display","none"); $(".menu-btn img").click(function() { $(".header-menu").toggle(200); }); }); </script>

前提・実現したいこと

jQueryのtoggleを使って表示非表示をしたいのです。
そして、menuでよく使われる3本線の入ったマークとばつ印(両方実装済み)の切り替えも教えていただきたいです。
ここに質問の内容を詳しく書いてください。
toggleを実装してクリックすると表示はされるのですが、非表示にできないです。

補足情報(FW/ツールのバージョンなど)

元のサイトのurlはhttp://bunkai-san.jp/です。
よろしくお願いします。
ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答2

0

ベストアンサー

目についたおかしな部分を指摘すると、

CSSのimgのleft: 1340px;
画面が狭いと画面からはみ出します。
right: で画面の右端を基準に位置決めするようにしましょう。

HTMLで三本線と×のボタン画像が別々のブロックになってますが、同じ位置でクリックで切り替えるので、同じブロックにいれましょう。
また、このブロックでボタンの位置決めをするといいでしょう。
さらに、このブロックのz-indexを大きくしてメニューブロックの上に来るようにします。そうしないとメニューが表示された時クリックできない。

jQuery ではこのブロックのクリック時で、メニューの表示切替、ボタン画像の切り替えをするようにします。

上記の点を考慮して、修正すると下記のようになります。

html

1<header> 2 <div class="inner"> 3 <div class="menu-btn"> 4 <img class="open" src="http://bunkai-san.jp/wp-content/themes/bunkaisan/img/sp-menu.png" alt=""> 5 <img class="close" src="http://bunkai-san.jp/wp-content/themes/bunkaisan/images/toggle-off.png" alt=""> 6 </div> 7 <ul class="header-menu"> 8 <li class="menu-btn01">CONCEPT</li> 9 <li class="menu-btn02">FLOOR GUIDE</li> 10 <li class="menu-btn03">NEWS</li> 11 <li class="menu-btn04">ACCESS INFO</li> 12 <li class="menu-btn05">CONTACT</li> 13 </ul> 14 <div class="header-logo"><a href="http://bunkai-san.jp/"><img src="http://bunkai-san.jp/wp-content/themes/bunkaisan/img/logo.png" alt=""></a></div> 15 </div> 16</header>

css

1.inner { 2 width: 100%; 3 overflow: hidden; 4} 5.inner ul { 6 list-style: none; 7 margin: 0; 8 padding: 0; 9} 10.header-menu { 11 display: flex; 12 justify-content: center; 13} 14 15.header-menu li { 16 font-family: 'Abel', sans-serif; 17 margin: 20px; 18} 19.menu-btn { 20 position: absolute; 21 top: 20px; 22 right: 50px; 23 width: 50px; 24 height: 50px; 25 z-index: 99; 26} 27.menu-btn img { 28 position: absolute; 29 width: 50px; 30 height: 50px; 31} 32 33main { 34 height: 800px; 35}

js

1$(function() { 2 $(".header-menu, .close").hide(); 3 $(".menu-btn").click(function() { 4 $(".header-menu").slideToggle(200); 5 $(".open, .close").fadeToggle(200); 6 }); 7});

動作確認用サンプル

上記で指摘した以外でもちょこちょこと修正してますので、もとのコードと見比べて違いを確認してみてください。

投稿2020/02/13 02:51

hatena19

総合スコア33715

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

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

katusi

2020/02/13 13:34

回答ありがとうございます。 完璧に上手くいきました!
guest

0

css指定しなければハンバーガー(?)ボタンで表示切り替えされますね
.menu-btn img のleftがスタティックに長く取りすぎていますが
その辺り大丈夫でしょうか?

投稿2020/02/13 00:23

yambejp

総合スコア114843

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問