🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

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

HTML

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

CSS

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

Q&A

解決済

2回答

1409閲覧

特定のクラス名から3の倍数のコンテンツを取り出し、スタイルを適応させたい

code2255

総合スコア2

JavaScript

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/03/29 23:22

編集2021/03/30 00:56

HTMLの中からis-activeというボックスの3の倍数のみにスタイルを適用させたいです。
is-activeの数を数えたあとか違う気がするのですが
教えていただきたいです

HTML

1<div class="outerBox"> 2<div class="box"></div> 3<div class="box"></div> 4<div class="box is-active"></div> 5<div class="box"></div> 6<div class="box is-active"></div> 7<div class="box is-active"></div> 8<div class="box is-active"></div> 9<div class="box"></div> 10<div class="box"></div> 11<div class="box"></div> 12<div class="box is-active"></div> 13<div class="box is-active"></div> 14<div class="box is-active"></div> 15<div class="box is-active"></div> 16</div> 17<!-- /.outerBox-->

jQuery

1$(function(){ 2 $('.outerBox .box').each(function () { 3 var count = $(this).find('.outerBox .is-active').length; 4 for (var i = 0; i < $(count).length; i++) { 5 if((i % 3) == 0) { 6 $(this).css({ 7 marginRight: '0' 8 }); 9 } 10 } 11 }); 12});

追加説明しますとフィルター機能を使って.is-activeのボックスだけ表示、
そのなかから3の倍数のボックスにスタイルを適用したいのですが、
.boxのみのクラスのもカウントされているらしくCSSが適用されません。

jQuery

1$('.menuProduct .sort').each(function(){ 2 $(this).click(function(){ 3 var value = $(this).attr('data-filter'); 4 var activeClass = 'is-active'; 5 if (value == 'all') { 6 $('.outerBox .box').show().addClass(activeClass); 7 } else { 8 $('.outerBox .box').not('.'+value).hide().removeClass(activeClass); 9 $('.outerBox .box').filter('.'+value).show().addClass(activeClass); 10 } 11 $(document).on('click', '.sort', function () { 12 $('.sort').removeClass('select'); 13 $(this).addClass('select'); 14 }); 15 }); 16 });

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

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

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

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

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

meg_

2021/03/30 00:08

> is-activeの数を数えたあとか違う気がする すみませんが上記文章の意味が分かりません。
guest

回答2

0

ベストアンサー

js

1 $('.outerBox .box').each(function () { 2 var count = $(this).find('.outerBox .is-active').length;

this.box ですから、その中に .outerBox .is-active は存在しません。

js

1 for (var i = 0; i < $(count).length; i++) {

count が既に長さの数値なのに、その.lengthを参照しようとしています。

js

1 if((i % 3) == 0) {

「3の倍数」が 3番目、6番目、9番目…とすると、配列の添字でいうと、[2] [5] [8] … です。

修正すると以下のようになります。

js

1$('.outerBox .box.is-active').each(function(i, element) { 2 if (i % 3 == 2) 3 $(element).css({marginRight: '0'}); 4});

投稿2021/03/30 00:20

int32_t

総合スコア21679

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

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

0

javascript

1$(function(){ 2 $('.box.is-active').filter(function(x){return x%3==2;}).css('backgroundColor','red'); 3});

投稿2021/03/30 00:14

yambejp

総合スコア116694

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問