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

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

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

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

jQuery

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

HTML

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

Q&A

解決済

2回答

544閲覧

jQuery:HTML子要素のテキストを探し当てて、その親要素にクラスを追加したい

SNTTNS

総合スコア3

JavaScript

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

jQuery

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

HTML

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

0グッド

0クリップ

投稿2021/12/01 05:30

編集2021/12/01 06:01

こんなHTMLテーブルがあるとします。
JSFIDDLEはこちら

HTML

1<table class="commonTable"> 2 <tbody> 3 <tr> 4 <td class="commonTd activeTd"> 5 <p>りんご</p> 6 </td> 7 <td class="commonTd"> 8 <p>レモン</p> 9 </td> 10 <td class="commonTd"> 11 <p>オレンジ</p> 12 </td> 13 </tr> 14 </tbody> 15</table>

この時、activeTdクラスのテキストは下記jQueryで取得できるのは分かるんです。

jQuery

1$(".commonTable .activeTd").innerText 2//りんごと出力される

しかし、

<p>レモン</p> という子要素が含まれる <td class="commonTd"> に、activeTdクラスを付与したい場合、どんなjQueryを書けばよいのでしょうか? 仮にtdタグにvalue="レモン"みたいに属性が付与されていれば簡単にセレクターが書ける気がしますが…

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

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

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

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

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

yambejp

2021/12/01 06:02 編集

<td class="commonTd"> <p>レ</p><p>モン</p> </td> みたいなものもヒットしていいのでしょうか?
SNTTNS

2021/12/01 06:02

質問いただきありがとうございます。 できればこれはヒットしたくないです。皆質問文のような感じに一行だけ<p>タグが入ります
guest

回答2

0

ベストアンサー

Lhankor_Mhyさんのを参考に、レモンが一続きであるものを前提とすると

javascript

1<style> 2.activeTd{ 3color:red; 4} 5</style> 6<script> 7$(function(){ 8 $('.commonTable .commonTd').has($('p:contains(レモン)')).addClass('activeTd'); 9}); 10</script> 11<table class="commonTable"> 12<tbody> 13<tr> 14<td class="commonTd activeTd"> 15<p>りんご</p> 16</td> 17<td class="commonTd"> 18<p>レモン</p> 19</td> 20<td class="commonTd"> 21<span></span><span>モン</span> 22</td> 23<td class="commonTd"> 24<p>オレンジ</p> 25</td> 26</tr> 27</tbody> 28</table>

投稿2021/12/01 06:25

編集2021/12/01 06:26
yambejp

総合スコア114863

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

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

SNTTNS

2021/12/01 06:38

回答ありがとうございます。 BA振ってしまいましたが、こちらの方が丁寧ですね!勉強になります。 お二方ともありがとうございました。
Lhankor_Mhy

2021/12/01 06:57

BAは変更できますので、よろしくお願いいたします。
guest

0

Select all elements that contain the specified text.

:contains() Selector | jQuery API Documentation

js

1$('.commonTd:contains("レモン")').addClass('activeTd')

投稿2021/12/01 05:48

Lhankor_Mhy

総合スコア36134

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

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

SNTTNS

2021/12/01 06:11

回答ありがとうございます。 多分これ惜しくて、考え方は理解できましたが、私がこのjQueryをそのままコピペして実行してみると下記エラーが発生します。 VM792:1 Uncaught DOMException: Failed to execute '$' on 'CommandLineAPI': '.commonTd:contains("レモン")' is not a valid selector. at <anonymous>:1:1 お手数ですが、なんとか直せないでしょうか?
Lhankor_Mhy

2021/12/01 06:18 編集

jQuery の読み込みを忘れているということはありませんか?
SNTTNS

2021/12/01 06:18

仰る通りjQueryを読み込み忘れておりました…大変失礼しました。 こちらベストアンサーとさせていただきます。 非常に助かりました。ありがとうございました!
Lhankor_Mhy

2021/12/01 06:19

お役に立てたようで何よりです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問