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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

Q&A

解決済

2回答

46535閲覧

クリックされたボタンの色を変更したり、それ以外の色を戻したりしたい

MeB

総合スコア104

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

0グッド

4クリップ

投稿2017/11/08 02:05

編集2017/11/08 02:39
  1. 例えばボタンが5つ並んでいるとしてそれの1つをクリックすると色が変わる。
  2. 別のボタンをクリックするとそれの色が変わり、最初にクリックしたボタンの色は初期の色に戻る
  3. ホバーではなくクリックしたら色は次のボタンがクリックされるまでそのまま

のようなことCSSで実現したいのですが検索してもなかなか見つからず
助言をいただければと思いこちらに質問させていただきました。
よろしくお願いいたします。

例(ここでは色を変えれないため太字にしてます。)

何もしていない状態
ボタン ボタン ボタン ボタン ボタン

クリック
ボタン ボタン ボタン ボタン ボタン

別のボタンをクリック
ボタン ボタン ボタン ボタン ボタン

さらに別のボタン
ボタン ボタン ボタン ボタン ボタン

タグにJavaScript, jQueryなどありますが、何が一番実装しやすいのかわからなかったためつけました。
CSSのみで実装できるならそれでCSSのみでお願いいたします。

下記は現在のhtmlソースになります

html

1 2<thead> 3 <tr> 4 <th> 5 <a>A</a> 6 <a>B</a> 7 </th> 8 <th> 9 <a>C</a> 10 <a>D</a> 11 </th> 12 <th> 13 <a>E</a> 14 <a>F</a> 15 </th> 16 <th> 17 <a>G</a> 18 <a>H</a> 19 </th> 20 <th> 21 <a>I</a> 22 <a>J</a> 23 </th> 24 </tr> 25</thead>

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2017/11/08 02:21

> CSSで実現したいのですが … CSSのみで実装ですか?タグにJavaScript, jQueryがありますが、JavaScriptでクラス付与など操作をしてCSSを適用させるということですか?
MeB

2017/11/08 02:28

何が一番実装しやすいのかわからなかったためタグにJavaScript, jQuery追加いたしました。ややこしくなってしまい申し訳ございません。
defghi1977

2017/11/08 02:39

ボタンがありませんよ
MeB

2017/11/08 02:43

ボタンという表現がよくありませんでした。buttomではなくaにcssでボタンっぽく見えるものでした。失礼しました。
guest

回答2

0

ベストアンサー

せめてHTMLのソースだけでも貼っていただきたいです。。。

html

1<!DOCTYPE html> 2<html> 3<head> 4<script type="text/javascript" src="https://code.jquery.com/jquery-latest.min.js"></script> 5<title>HTML, CSS and JavaScript demo</title> 6</head> 7<body> 8 <button>ボタン</button> 9 <button>ボタン</button> 10 <button>ボタン</button> 11 <button>ボタン</button> 12 <button>ボタン</button> 13</body> 14</html>

cssソース

css

1button { 2 width: 100px; 3 height: 40px; 4 border: 1px solid #ccc; 5 background-color: white; 6 color: #000000; 7} 8 9.active { 10 background-color: red; 11 color: white; 12}

jQueryソース

javascript

1$(function(){ 2 var btn = $('button'); 3 btn.click(function(){ 4 btn.removeClass('active'); 5 $(this).addClass('active'); 6 }); 7});

上記でおそらく実現したいことが出来ると思います。
上記ソースの解説ですが、クリックをすると、.activeというクラスが付与されます。
.activeというクラスにはbackground-color: red;となっているので、付与されると背景色が変わります。
違うボタンをクリックすると、クラスが付与される前にremoveClassで一度activeクラスを外しているので、リセットされ再度クラスの付与が行われます。

こちらであってますでしょうか?

投稿2017/11/08 02:27

編集2017/11/08 02:36
kenny_sayama

総合スコア1036

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

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

kenny_sayama

2017/11/08 02:28

CSSだけでという部分を見逃していました。
MeB

2017/11/08 02:33

いえいえ!こちらこそソースも貼らずに申し訳ございません。
kenny_sayama

2017/11/08 02:37

簡単にということであれば、上記ソースが簡単に実現出来るかと思います。 CSSだけでやろうとするとかえってわかりづらくなってしまうかと思います。。。
MeB

2017/11/08 02:39

承知しました。ありがとうございます。試してみます!
optimist06

2019/06/13 11:02

自分好みのボタンが何とか作れないかと、あちこち探し回っていたら、 こちらにたどり着きました。 おかげさまで、自分が作りたいと思っていた通りのボタンが作れました。 http://kassenba.sakura.ne.jp/ 大変感謝しております。ありがとうございました。
guest

0

label要素とinput[type=radio]要素と隣接セレクタ+,:checked疑似クラスでボタンぽいものを作るとか

HTML

1<style> 2input[type=radio]{ 3 display: none; 4} 5:checked + span{ 6 font-weight: bold; 7} 8</style> 9<label><input type="radio" name="r"/><span>ボタン</span></label> 10<label><input type="radio" name="r"/><span>ボタン</span></label> 11<label><input type="radio" name="r"/><span>ボタン</span></label> 12<label><input type="radio" name="r"/><span>ボタン</span></label> 13<label><input type="radio" name="r"/><span>ボタン</span></label>

投稿2017/11/08 02:26

defghi1977

総合スコア4756

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問