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

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

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

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

HTML

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

CSS

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

Q&A

解決済

1回答

2691閲覧

サイドバーをjavascriptで表示させたい

takuma1217

総合スコア20

JavaScript

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2019/05/14 16:33

前提・実現したいこと

javascriptでボタンを押すとサイドバーが出る仕組みを実装したい

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

サイドバーが表示されない

該当のソースコード

html

1 <div id="open"> 2 <i class="fas fa-bars open-btn"></i> 3 </div> 4 <div id="side-bar"> 5 <div id="close"> 6 <i class="fas fa-times fa-2x"></i> 7 </div> 8 </div>

css

1#side-bar{ 2 display:none; 3} 4 5#side-bar.active{ 6 display:block; 7}

javascript

1'use strit'; 2const open = document.getElementById('open'); 3const close = document.getElementById('close'); 4const sideBar = document.getElementById('side-bar'); 5const body = document.querySelector('body'); 6 7open.addEventListener('click',()=>{ 8 sideBar.classList.add('active'); 9}); 10 11close.addEventListener('click',()=>{ 12 sideBar.classList.remove('active'); 13}); 14body.addEventListener('click',()=>{ 15 sideBar.classList.remove('active'); 16});

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

#openをつけた領域をクリックするとサイドバーが現れ、side-barの中の#closeをクリックするとsidebarがきえるようにしたいです。
javascriptのコードを書いた経験あまりないので基本的な間違いが原因なら申し訳ございません

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

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

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

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

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

guest

回答1

0

ベストアンサー

イベントはルートの要素まで伝わっていくので。

js

1'use strit'; 2const open = document.getElementById('open'); 3const close = document.getElementById('close'); 4const sideBar = document.getElementById('side-bar'); 5const body = document.querySelector('body'); 6 7open.addEventListener('click',event=>{ // 8 sideBar.classList.toggle('active'); 9 event.stopPropagation(); // 10}); 11 12close.addEventListener('click',event=>{ // 13 sideBar.classList.remove('active'); 14 event.stopPropagation(); // 15}); 16body.addEventListener('click',()=>{ 17 sideBar.classList.remove('active'); 18}); 19```**動くサンプル:**[https://jsfiddle.net/5rz6em9g/](https://jsfiddle.net/5rz6em9g/) 20 21--- 22 23【event.stopPropagation - Web API | MDN24[https://developer.mozilla.org/ja/docs/Web/API/Event/stopPropagation](https://developer.mozilla.org/ja/docs/Web/API/Event/stopPropagation) 25 26DOMイベントのキャプチャ/バブリングを整理する 〜 JSおくのほそ道 #017 - Qiita】 27[https://qiita.com/hosomichi/items/49500fea5fdf43f59c58](https://qiita.com/hosomichi/items/49500fea5fdf43f59c58) 28 29[速攻理解] preventDefault() とstopPropagation()の違い - Qiita】 30[https://qiita.com/sudokzt/items/411b2d0a16f0cd8c40ab](https://qiita.com/sudokzt/items/411b2d0a16f0cd8c40ab)

投稿2019/05/14 17:32

kei344

総合スコア69407

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問