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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

HTML

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

Q&A

解決済

2回答

730閲覧

javascriptでIDで取得したもののフォントカラーを変更しても1つしか適用されない。

Kuro515

総合スコア25

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

HTML

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

0グッド

0クリップ

投稿2021/06/17 12:27

編集2021/06/17 12:27

JavascriptとHTMLを使っています。
ボタンが押されたら文字色を変えるコードを書きました。

PHPでデータベース(MySQL)を取得してそれをテーブルに表示させています。そして、
最初の文字色を白にして、「表示」ボタンを押したら赤くして「解答」の部分を表示させたいと思っています。

PHP

1 $pdo = new PDO($connect, $db_user, $db_pass, array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8')); 2 $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); 3 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 4 5 echo "<p>Success!!</p>"; 6 7 $sql = "SELECT name,comment FROM board"; 8 $stmt = $pdo->prepare($sql); 9 $stmt->execute(); 10 11 $result = $stmt->fetchAll(PDO::FETCH_ASSOC);

HTML

1<html> 2<head> 3<link rel="stylesheet" href="style2.css"> 4</head> 5<body> 6<table class="sample" align="center"> 7 <tr> 8 <th>チーム名</th> 9 <th>解答</th> 10 </tr> 11 <?php foreach ($result as $row) {?> 12 <tr> 13 <td><?php echo $row['name']; ?></td> 14 <td id="an" style="color:white"><?php echo $row['comment']; ?></td> 15 </tr> 16 <?php } ?> 17</table> 18<br> 19<form action="" method="post"> 20 <button type="button" name="open" class="Form-Btn" id="my_button" onclick="changeColor()">表示</button> 21</html>

javascript

1function changeColor(){ 2 var obj = document.getElementById('an'); 3 document.getElementById("an").style.color = "red"; 4}

しかし、最初の1行目しか色が変わりません。

上の写真のような状況です。

何が問題なのでしょうか?

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

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

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

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

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

guest

回答2

0

「ID」は特定できる要素でなければなりません。
同ページ内に重複は構文としてNGです。
classは重複OKなので同名classを振って対応してください。

投稿2021/06/17 12:32

m.ts10806

総合スコア80875

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

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

0

ベストアンサー

そもそも同じidを持つ要素を複数持つことはできません。
やるならidではなくclassでしょうね。
で、たとえばこんな風に処理します。

JavaScript

1let elements = document.getElementsByClassName('an'); 2let elementArray = Array.from(elements); 3elementArray.forEach(function(e) { 4 e.style.color = "red"; 5});

getElementsByClassNameが返す値は配列風オブジェクトです。
それを配列に変換し、forEachで回して、各要素のスタイルを変更します。

投稿2021/06/17 12:36

itagagaki

総合スコア8402

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問