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

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

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

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

HTML

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

CSS

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

Q&A

解決済

2回答

924閲覧

buttonの子要素にクラスを付けたいがつかない

KKsall

総合スコア25

JavaScript

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

HTML

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

CSS

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

0グッド

1クリップ

投稿2021/11/06 12:22

buttonの子要素に<i class="fas fa-chevron-right"></i>に.reflectをつけてアイコンをclickで反転させたいです。
親要素の<button type="button" class="c-scroll-button border-radius">にはクラスがつくのですが、<i class="fas fa-chevron-right"></i>にするとつきません。

<button type="button" class="c-scroll-button border-radius"> <i class="fas fa-chevron-right"></i><i class="fas fa-chevron-right"></i> </button>
icon.querySelectorAll('.fas') icon.addEventListener('click', function(){ this.classList.toggle('reflect'); });
.c-scroll-button.reflect{ transform: scale(-1, 1); transition: transform 500ms ease-out; }

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

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

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

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

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

guest

回答2

0

ベストアンサー

やりたいことは下記のようなことかな?

css

1.c-scroll-button i { 2 transition: transform 500ms ease-out; 3} 4.c-scroll-button i.reflect{ 5 transform: scale(-1, 1); 6}

js

1const icons = document.querySelectorAll('.c-scroll-button i.fas'); 2 3icons.forEach((icon) => { 4 icon.addEventListener('click', function(){ 5 this.classList.toggle('reflect'); 6 }); 7});

それともこちらか?

css

1.c-scroll-button { 2transition: transform 500ms ease-out; 3} 4.c-scroll-button.reflect{ 5 transform: scale(-1, 1); 6}

js

1const scrollButton = document.querySelector('.c-scroll-button'); 2 3scrollButton.addEventListener('click', function(){ 4 this.classList.toggle('reflect'); 5});

正解は下記でした。

css

1.c-scroll-button i { 2transition: transform 500ms ease-out; 3} 4.c-scroll-button.reflect i { 5 transform: scale(-1, 1); 6}

スクリプトは上と同じ。

投稿2021/11/06 12:51

編集2021/11/06 13:20
hatena19

総合スコア34075

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

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

KKsall

2021/11/06 13:46 編集

あと少しで手が届きそうです!「それともこちらか?」の内容でclickで反転するのはアイコンだけでいいんですよね。アイコンの反転は最初のものでOKで、clickでの動きは2つ目のものでclickするたびにアイコンが反転する感じです
hatena19

2021/11/06 13:15

CSS を下記にしてください。 .c-scroll-button i { transition: transform 500ms ease-out; } .c-scroll-button.reflect i{ transform: scale(-1, 1); }
KKsall

2021/11/06 13:16

ありがとうございます!!できました
guest

0

回答作ってる間に即効レスついてた><

forEachのほうがスマートなので、hatena19さんの回答を支持します。
まぁ、私のはわかりやすいforでやったらこうなるよって感じで・・・

html

1<!DOCTYPE html> 2<html lang="jp"> 3 <head> 4 <meta charset="UTF-8"> 5 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 6 <meta http-equiv="X-UA-Compatible" content="IE=edge"/> 7 <meta name="format-detection" content="telephone=no"> 8 <title>reflect test</title> 9 <link rel="stylesheet" href="https://pro.fontawesome.com/releases/v5.10.0/css/all.css" integrity="sha384-AYmEC3Yw5cVb3ZcuHtOA93w35dYTsvhLPVnYs9eStHfGJvOvKxVfELGroGkvsg+p" crossorigin="anonymous"/> 10 <style> 11 .c-scroll-button.reflect{ 12 transform: scale(-1, 1); 13 transition: transform 500ms ease-out; 14 } 15 </style> 16 </head> 17 <body> 18 <button type="button" class="c-scroll-button border-radius"> 19 <i class="fas fa-chevron-right"></i><i class="fas fa-chevron-right"></i> 20 </button> 21 22 <script> 23 var icon = document.querySelectorAll('.fas'); 24 var iconLength = icon.length; 25 for (var i=0; i < iconLength; i++) { 26 icon[i].addEventListener('click', function(){ 27 this.classList.toggle('reflect'); 28 }); 29 } 30 </script> 31 </body> 32</html>

肝心なのは、querySelectorAllで引っ張ってくると要素の配列(複数個の要素の集合体)で
返ってくる。
そして、配列にはaddEventListenerは付けられないので、意図した動作にならなかった。
何がしかの方法で、要素1つ1つにaddEventListenerをくっつけてやる必要がある。

それをforでやるかfotEachでやるかの違いだけです。

投稿2021/11/06 13:01

編集2021/11/06 13:13
nekora

総合スコア501

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

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

nekora

2021/11/06 13:05

回答が役になったなら回答の横の数字をポイントすると回答の評価の増減ができます。 また解決につながった回答はベストアンサーに指定できます。 この設定は個別に指定できますし、同時に指定することもできます。
KKsall

2021/11/06 13:17

色々ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問