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

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

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

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

Q&A

解決済

2回答

2806閲覧

document.getElementsByClassNameが機能しない

imaharu

総合スコア32

JavaScript

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

0グッド

0クリップ

投稿2017/08/12 06:57

ByIdは効くがByClassNameが機能しない

<a>show</a>をclickした時にパスワードを可視化させるプログラムを組んでいる途中で
aタグにclassをつけ、javascriptで操作しようとした所
取得がうまくいかないです

idをつかっても問題ないのですが、後学のために教えていただきたいです

よろしくお願いします

以下コード

<!DOCTYPE html> <html lang="ja"> <title></title> <head> <link rel="stylesheet" type="text/css" href="style.css"> <script type="text/javascript"> function show_id() { alert("check id"); var show_id = document.getElementById("show_id"); show_id.innerHTML = "id"; }; function show_class() { alert("check class"); var show_class = document.getElementsByClassName("show_class"); show_class.innerHTML = "class"; }; </script> </head> <body> <li> <label for="password">パスワード</label> <input type="password" name="password" id="password"> <a href="#" id="show_id" onclick="show_id()">Show_id</a> <a href="#" class="show_class" onclick="show_class()">Show_class</a> </li> </body> </html>

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

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

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

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

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

guest

回答2

0

getElementByIdの返り値はElementのため、記述のJavaScriptで問題ありませんが、
getElementsByClassNameの返り値はHTMLCollectionのため、以下のように添え字でHTMLCollection内のどのElementに対して処理を行うか記述する必要があります(今回のケースでは一つしか返ってこないので、自動的に添え字は「0」となりますが。

javascript

1show_class[0].innerHTML = "class";

投稿2017/08/12 07:12

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

imaharu

2017/08/12 07:23

回答ありがとうございました 無事解決しました
guest

0

ベストアンサー

getElementsByClassNameは配列ライクなオブジェクトを返します。
例示されているhtml上ではshow_classというクラスは一つしかありませんので、
show_class[0]で指定できます。

var show_class = document.getElementsByClassName("show_class"); //console.log(show_class); show_class[0].innerHTML = "class";

投稿2017/08/12 07:06

namimon

総合スコア726

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

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

imaharu

2017/08/12 13:19 編集

回答ありがとうございます 追加で質問なのですが、多数のclassに対して変更を行う場合 for(let i = 0;i < 3;i++){ show_class[i].innerHTML = "class" } のような形でしか、変更できないのでしょうか。 これだと、あとからhtmlを追加、削除したときに 不便だと思うのですが、もっと良い方法はあるのでしょうか よろしくお願いします
zohnam

2017/08/12 07:34

配列そっくりなオブジェクトですから、配列同様に.lengthプロパティがあります。 for(let i = 0;i < show_class.length;i++){ show_class[i].innerHTML = "class" } となりますね。
namimon

2017/08/12 08:15

回答の表示順は、回答された順ではないことだけ知っていただければ、心残りありません
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問