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

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

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

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

プラグイン

プラグイン(plug-in)は、ソフトウェアアプリケーションの機能拡張の為に開発された、一組のソフトウェアコンポーネントのことを指します。

jQuery

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

Q&A

0回答

435閲覧

絞り込み検索後に対象ワードを含んでないliは名前部分のdiv要素も非表示にしたい

hannes

総合スコア3

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

プラグイン

プラグイン(plug-in)は、ソフトウェアアプリケーションの機能拡張の為に開発された、一組のソフトウェアコンポーネントのことを指します。

jQuery

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

0グッド

0クリップ

投稿2020/10/12 15:11

編集2020/10/13 01:47
<!DOCTYPE html> <html lang="jp"> <head> <meta charset="UTF-8"> <title>絞り込みJS</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script> <script src="https://webkaru.net/jquery-plugin/sources/lookingfor/jquery.lookingfor.js"></script> <style> *{ list-style: none; } </style> </head> <body> <input type="text"id="word"> <div id="target"> <div class="modal_message_list" id="message_list1"> <ul> <li> <div class="modal_message_prof"> <label>山田太郎</label> </div> <p class="modal_message_txt"> コメント123 </p> </li> <li> <div class="modal_message_prof"> <label>鈴木太郎</label> </div> <p class="modal_message_txt"> コメント456 </p> </li> </ul> </div> </div> <script> jQuery(function($) { $('#target').lookingfor({ input: $('#word'), items: 'li .modal_message_txt', highlight: true, onFound: function(){ //カスタマイズした部分 // $(".modal_message_list>ul>li").each(function(idx, ele){ // var eleTarget= $(this).find(".modal_message_txt>.lfitem_match"); // if(eleTarget.length <= 0){ // $(this).hide(); // } // }); } }); }); </script> </body> </html>

下記プラグインを使用しているのですが、テキスト部分だけに検索をかけたいので、検索後に対象ワードを含んでないliは名前部分のdiv要素も非表示にしたいです。
プラグインから付与されるclassを使用し途中までカスタマイズしたのですが、今度はinputが空になったときにliを戻したいのですがうまく動作致しません。
自分でカスタマイズはしましたが、実現できればこの方法以外でも構いません。
何か良い方法があればご教授お願い致します。

使用プラグイン
https://github.com/albburtsev/jquery.lookingfor

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

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

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

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

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

hannes

2020/10/12 16:06

liに対して検索をあててしまうと名前も検索されてしまうので、p要素の中のテキストだけを検索したいです。 その時に該当ワードがなくても検索結果に名前部分が残ってしまうので、その部分を非表示にしたいということです。
kuma_kuma_

2020/10/13 08:21

> p要素の中のテキストだけを検索したいです。 先のサンプルURLみたいな仕組みでテキスト部分は<p>タグだけにしたいという事ですね > 該当ワードがなくても検索結果に名前部分が残ってしまう いまの状態だと<p>タグ以外に検索が当たっているので同じように黄色の選択が<label>にも起こってしまうという解釈でよろしいですか?
hannes

2020/10/13 17:17

>先のサンプルURLみたいな仕組みでテキスト部分は<p>タグだけにしたいという事ですね はい >いまの状態だと<p>タグ以外に検索が当たっているので同じように黄色の選択が<label>にも起こってしまうという解釈でよろしいですか? 正確に言いますと私のサンプルですと<p>タグの.modal_message_txtに検索が当たっています。 この状態で該当ワードがない時に名前部分の<div>を消したいです。 例)123と検索→鈴木太郎は消す もしくはliに検索をあてて、名前部分の<label>に検索が起こらないようにする、でもよいかと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問