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

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

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

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

HTML

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

CSS

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

Q&A

解決済

1回答

2782閲覧

jsバナーをクリックして開閉させたい

ysy

総合スコア13

JavaScript

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2018/03/19 23:46

前提・実現したいこと

初めまして、よろしくお願いします。
jsを使って、画面の右サイドに、クリックで開閉可能なメニューバナーを作りたいと思っています。

発生している問題・エラーメッセージ

一度クリックすると引っ込むのですが、2回目以降にクリックすると出てきてくれません。(反応しません) クリック毎に開閉するようにしたいです。

該当のソースコード

<html> <head> <style> #slideR { z-index: 99; cursor: pointer; position: fixed; top: 40%; right: -140px; background: #0DCEA8; width: 180px; color: #fff; font-size: 16px; } </style> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script> <script> //マウスオーバーで表示 $(function() { $('#slideR').click( function(){ $(this).animate({'marginRight':'140px'},500); }, function () { $(this).animate({'marginRight':'0'},500); } ); }); </script> </head> <body> <nav id="slideR" style="margin-right: 140px;"> <span class="nav-icon"><i class="fa fa-heart-o"></i></span> <ul> <li><a href="#">Top</a></li> <li><a href="#">About</a></li> <li><a href="#">Content</a></li> <li><a href="#">Mail</a></li> </ul> </nav> </body> </html>

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

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

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

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

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

guest

回答1

0

ベストアンサー

コメントに「マウスオーバーで表示」とありますが、クリックでの表示非表示切替で良いですか?
であれば、pen作ってきたので見て下さい。

https://codepen.io/Reek/pen/wmgdMx

・JS側ではクリックされる毎に#slideRにcssクラス 「.active」の付与と削除を交互に行います。(toggleClass)
・CSS側では#slideRに.activeが付与された状態「#slideR.active」に対してright:0;としています。
・アニメーションしてほしいので、#slideRにはtransition:.4s;を指定しました。(0.4秒間で-140pxから0pxへ遷移します)

この様に、JSでは状態の変化だけを行いCSSでアニメーション設定を行うと考え方的に簡単になると思います。

投稿2018/03/20 00:02

編集2018/03/20 00:20
shaak

総合スコア607

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

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

ysy

2018/03/20 01:04 編集

早速ありがとうございます!助かります。 JS初心者なので詳しい解説も参考にさせて頂きます。 ちなみに、デフォルトでメニューが出た状態からにしたいのですが、お教え頂く事はできますでしょうか? <追記> すみません、CSSのrightを変更する事でできました。 どうもありがとうございました。
shaak

2018/03/20 01:04

前にご説明した通り、JS側では#slideRに対してclass activeの付与と削除を交互にしています。 メニューが出た状態から始めたければ <nav id="slideR" class='active'> と、html側のデフォルト状態をclass activeにすれば良いです。
ysy

2018/03/20 01:36

重ね重ね、詳細な説明ありがとうございます。 お教え頂いたやり方の方がスマートですね。 どうもありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問