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

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

詳細はこちら
JavaScript

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

jQuery

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

Q&A

解決済

2回答

2020閲覧

【jQuery】配列の中にある値とdiv要素のidの値が一致する場合、div要素に特定のクラス名を付与したい

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2019/12/08 12:23

■ 最終的なゴール

Ajaxを用いてAPI(カラーミーショップ)で情報を取得し、APIで取得した情報と一致する値を持つp要素がある場合、p要素に特定のクラス名を付与したい。

■ そのためにやりたいこと

配列の中の情報と、情報と一致するidを持つp要素に特定のクラス名を付与したい。

■ 現在

上記を実行するために、jQueryで適当な配列を作り、idを付与したdiv要素を並べ、配列の中身とp要素のidが一致した場合、p要素にpinkクラスを付与するというコードを書いていたのですが、つまづきました。

配列に"100"と"300"があるため、下記2つのpタグにpinkクラスを付与したいです。

<p id="100" class="itembox">あああ</p> <p id="300" class="itembox">ううう</p>

html

1<body> 2 <style type="text/css"> 3 .pink { 4 color:pink; 5 } 6 </style> 7 <p id="100" class="itembox">あああ</p> 8 <p id="200" class="itembox">いいい</p> 9 <p id="300" class="itembox">ううう</p> 10 <p id="400" class="itembox">えええ</p> 11 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 12 <script type="text/javascript"> 13 $(function() { 14 15 var check = $('p.itembox'); // itemboxクラスを持つpタグを取得 16 var numbers = [ 100, 150, 245, 300, 415 ]; 17 var b = $.grep(numbers, function(e){ return e; }); 18 19 $(check).each(function (i) { 20 var checkid = $(this).attr('id'); 21 if (checkid == b) { 22 $(this).addClass('pink'); 23 } 24 }); 25 }); 26 </script> 27</body>

■ 試したこと

inArrayも試しましたが、"0"または"-1"という値しか返ってこなかったため、諦めました。

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

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

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

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

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

guest

回答2

0

html

1<script type="text/javascript"> 2 $(function() { 3 var check = $('p.itembox'); // itemboxクラスを持つpタグを取得 4 var numbers = [ 100, 150, 245, 300, 415 ]; 5 for (var i = 0; i<numbers.length; i++) { 6 $('p.itembox#' + num).addClass('pink'); 7 } 8 }); 9</script>

投稿2019/12/08 15:33

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

kei344

2019/12/08 15:40

num ⇒ numbers[i] では?
退会済みユーザー

退会済みユーザー

2019/12/08 17:52

あ、、、
退会済みユーザー

退会済みユーザー

2019/12/08 18:35

回答いただき、誠に有難うございます。 また、kei344様も修正していただき、有難うございます。 どちらも甲乙つけがたかったのですが、先に回答していただいた方をベストアンサーとさせていただきました。
guest

0

ベストアンサー

$.inArrayの戻り値は、

  • 含まれている場合はその位置
  • 含まれていない場合は-1

を戻します。なので、以下のようなコードで判定できます。

javascript

1$(function() { 2 3 var check = $('p.itembox'); // itemboxクラスを持つpタグを取得 4 var numbers = [100, 150, 245, 300, 415]; 5 6 $(check).each(function(i, elm) { 7 //下記のままだと、型不一致(elm.idは文字列型 numbersは数値型)で、すべてfals判定になってしまいます 8 //if ($.inArray(elm.id, numbers)!=-1) $(elm).addClass('pink'); 9 10 //elm.idが数値変換可能であることを条件として、下記で判定可能です 11 if ($.inArray(elm.id-0, numbers)!=-1) $(elm).addClass('pink'); 12 13 //もしくは、以下のように、numbers側を文字列の配列に切り替えましょう 14 //var numbers = [100, 150, 245, 300, 415].map(function(n){ return n+''}); 15 16 }); 17});

投稿2019/12/08 15:28

satoshi_tajima

総合スコア337

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

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

退会済みユーザー

退会済みユーザー

2019/12/08 18:36

回答いただき、誠に有難うございます。 上記で解決しました。 本当に有難うございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問