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

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

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

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

HTML

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

CSS

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

Chrome extension

Chrome拡張機能

Q&A

解決済

2回答

2566閲覧

JavascriptでCSS(width)を書き換えたいです

ghost238_gen

総合スコア16

JavaScript

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

HTML

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

CSS

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

Chrome extension

Chrome拡張機能

0グッド

0クリップ

投稿2020/08/24 08:55

編集2020/08/24 09:11

JavascriptでCSSを書き換える

現在、Javascriptの勉強を兼ねてchrome拡張機能にの開発に取り組んでいます。
特定のページに表示されているtableレイアウトのwidthを100%に変更し、
ページを見やすくする機能を作っていこうと思っているのですが、
CSSソースを確認するとIDとクラスを一つに省略して記述してありました。

getElementsByidやgetElementsByclassnameで要素を抽出できるのはわかりましたが
両方に該当する場合はどのような書き方をすればいいでしょう?

教えていただけると幸いです。

該当のソースコード

CSS

1#aaa .bbb{ 2 width: 800px; 3}

js

1window.onload = function() { 2 var body = document.getElementsByClassName('bbb'); 3 body[0].style.width = '100%'; 4};

試したこと

上記JSにてclassを抽出、指定することで一部の対象はwidthが100%になりました

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

akihiro3

2020/08/24 09:12

全ての.bbbをwidth:100%にしたいという事ですか?
ghost238_gen

2020/08/24 09:17

そうです! 説明不足ですみません。
guest

回答2

0

ベストアンサー

forEachを使えばいいのですが、
HTMLCollectionになるので配列にする必要があります。

js

1body = Array.from( body ); 2body.forEach(function(e) { 3 e.style.width = '100%'; 4});

もしくは、

js

1Array.prototype.forEach.call(body, function(e) { 2 e.style.width = '100%'; 3});

要素の取得にquerySelectorを使えばそのままforEachが使えます。

js

1var body = document.querySelectorAll('.bbb'); 2body.forEach(function(e) { 3 e.style.width = '100%'; 4});

###追記

#aaaかつ.bodyの指定をもし考えているのならば、同じページ内にidは複数使えないので、
idだけでいいと思います。
必要ならば.bodyは別途記述です。

js

1 var body = document.getElementsByClassName('body'); 2 var aaa = document.getElementById('aaa'); 3 4 aaa.style.width = '100%'; 5 6 Array.prototype.forEach.call(body, function(e) { 7 e.style.width = '100%'; 8 });

投稿2020/08/24 09:45

編集2020/08/24 10:30
akihiro3

総合スコア955

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

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

0

両方に該当する場合はどのような書き方をすればいいでしょう?

idclassの両方を指定したいのならquerySelectorが有効です。

javascript

1// id="aaa"でclass="bbb"を取得 2document.querySelector('#aaa.bbb')

今回は対象が複数あるようなのでquerySelectorAllを利用しましょう。

javascript

1document.querySelectorAll('#aaa.bbb')

投稿2020/08/24 09:35

nekoniki

総合スコア2411

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問