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

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

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

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

Q&A

解決済

1回答

364閲覧

containsを使って非表示にしたい

helpmee88

総合スコア4

jQuery

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

0グッド

0クリップ

投稿2023/04/26 04:56

実現したいこと

任意の文字が表示されているときに子カテゴリを非表示にしたい

前提

親カテゴリ→大カテゴリ→子カテゴリの3階層で構成されています。
大カテゴリをクリックすると、大カテゴリ表示名の下に子カテゴリ一覧が表示される仕組みです。
子カテゴリの件数が多いため、大カテゴリの表示状態では、子カテゴリを非表示にしたいです。

内容

非表示するにあたり、指定できるのは大カテゴリ名のテキスト内容だけです。
そのため、jqueryのcontainsを使って、テキストを指定しているのですが、全く一致しないテキスト内容でも適用され、非表示になってしまいます。
どのようにすれば完全一致の指定ができるのでしょうか?
お忙しい中恐縮ですが、どなたかご教授いただけませんでしょうか。
何卒、よろしくお願いいたします。

該当のソースコード

1行目の<section class="__heading">が指定したい大カテゴリです。
6行目の<section class="class="__list __list--row">が非表示にしたい子カテゴリ一覧です。

html

1<section class="__heading"> 2 <h1 class="__h1 c-h1">POM(ポリアセタール)</h1> 3</section> 4<section class="__child" id="kuri-110"></section> 5<section class="__control"></section> 6<section class="class="__list __list--row"></section>

試したこと

このソースを動かしたところ、全く一致しない他のカテゴリ名(例:ABS(アクリロニトリルブタ ジエンスチレンコポリマー))でも適用され".__list"が非表示になってしまいました。

js

1//大カテゴリ表示の場合、子カテゴリを表示させない 2$(function(){ 3 $("h1:contains('POM(ポリアセタール)')"); { 4 $(".__list").hide(); 5 } 6});

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

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

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

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

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

int32_t

2023/04/26 05:05

具体的な回答を書くには、もっと広い範囲のHTMLの構造を知る必要があります。問題を再現できるHTMLソース全体を開示できないでしょうか。少なくとも、__heading の親の情報や間違って非表示になる __list の位置関係は必要です。
guest

回答1

0

ベストアンサー

js

1 $("h1:contains('POM(ポリアセタール)')"); { 2 $(".__list").hide(); 3 }

これは、以下のコードと同じです。

js

1 $("h1:contains('POM(ポリアセタール)')"); 2 $(".__list").hide();

POM(ポリアセタール) を含む <h1> のリストを取得して何もしない。次に .__list にマッチする要素すべてを非表示する」というコードです。

情報が足りないので対処方法は書けません。少なくとも if は使うでしょうね。

投稿2023/04/26 05:08

編集2023/04/26 05:11
int32_t

総合スコア20884

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

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

helpmee88

2023/04/26 05:24

早急にご回答いただきまして、ありがとうございます! とてもわかりやすくご指摘いただいたので、考えてみました。 そうしたところ、 --------------------- $(function(){ if ($("h1:contains('POM(ポリアセタール)')").is(':visible')) { $(".__list").hide(); } }); --------------------- 上記で動かしたところ、ちゃんと適応できました。 心より感謝いたします。 また、悩んだ時に回答いただけると大変嬉しいです。 お忙しい中、お力添えをいただきましてありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問