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

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

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

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

jQuery

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

HTML

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

CSS

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

Q&A

0回答

1161閲覧

絞り込み機能と「もっと見る」を同時に使いたい

rightbrain

総合スコア3

JavaScript

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

jQuery

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/03/26 07:05

編集2021/03/26 08:30

どこを編集すればよいか分からずにいます。
ご教示いただけますと幸いです。宜しくお願い致します。

現在の状況

・「ALL」を選択時のみ「もっと見る」と「表示を戻す」ボタンが表示される
・「もっと見る」をクリックすると、10件目以降の記事が10件ずつ表示される
・カテゴリは1つのみ選択できる

実現したいこと

・「全表示」だけではなく、各カテゴリで表示した時にも10件以上ある場合は「もっと見る」を使えるようにしたい
・カテゴリは1つのみではなく、複数選択できるようにしたい

追記

$('#more_btn').hide(); を削除したところ、「もっと見る」が各カテゴリにも表示されました。
ですがクリックすると、該当のカテゴリ以外の記事も表示されてしまいます。
選択しているカテゴリの記事のみを表示させたいです。

該当のソースコード

<html> <head> <!--jQueryソース--> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script> </head> <!--最低限のCSS--> <style> .is-hide{ display: none; } .is-active{ color: red; } </style> <body> <div id="page works-main">  <div class="search searchList categories">   <span class="search_item is-active" data-group="">ALL</span>   <span class="search_item" data-group="a">カテゴリA</span>   <span class="search_item" data-group="b">カテゴリB</span>   <span class="search_item" data-group="c">カテゴリC</span>   <span class="search_item" data-group="d">カテゴリD</span>   <span class="search_item" data-group="e">カテゴリE</span>  </div>  <div id="entry_list_more" id="gallery">   <!-- /記事一覧 --> <ul class="list">    <li class="list_item" data-group="a">1件目の記事</li>    <li class="list_item" data-group="a">2件目の記事</li>    <li class="list_item" data-group="a">3件目の記事</li>    <li class="list_item" data-group="a">4件目の記事</li>    <li class="list_item" data-group="b">5件目の記事</li>    <li class="list_item" data-group="b">6件目の記事</li>    <li class="list_item" data-group="b">7件目の記事</li>    <li class="list_item" data-group="b">8件目の記事</li>    <li class="list_item" data-group="b">9件目の記事</li>    <li class="list_item" data-group="c">10件目の記事</li>    <li class="list_item" data-group="d">11件目の記事</li>    <li class="list_item" data-group="d">12件目の記事</li>    <li class="list_item" data-group="d">13件目の記事</li>    <li class="list_item" data-group="d">14件目の記事</li>    <li class="list_item" data-group="e">15件目の記事</li>    <li class="list_item" data-group="e">16件目の記事</li>    <li class="list_item" data-group="e">17件目の記事</li>    <li class="list_item" data-group="e">18件目の記事</li>    <li class="list_item" data-group="e">19件目の記事</li>    <li class="list_item" data-group="e">20件目の記事</li>    <li class="list_item" data-group="e">21件目の記事</li>    <li class="list_item" data-group="e">22件目の記事</li>    <li class="list_item" data-group="e">23件目の記事</li>    <li class="list_item" data-group="e">24件目の記事</li>    <li class="list_item" data-group="e">25件目の記事</li>    <li class="list_item" data-group="e">26件目の記事</li> </ul>    <div id="more_btn">もっと見る <i class="fa fa-chevron-down" aria-hidden="true"></i></div>    <div id="close_btn">表示を戻す <i class="fa fa-chevron-up" aria-hidden="true"></i></div> </div> </body> </html> <script>  var searchItem = '.search_item';  var listItem = '.list_item';  var hideClass = 'is-hide';  var activeClass = 'is-active';  $(function() { $(searchItem).on('click', function() { $(listItem).removeClass(hideClass); //hideclassを削除 $('.list_item').css('display',''); //すべて表示 $(searchItem).removeClass(activeClass); var group = $(this).addClass(activeClass).data('group'); if(group==""){ //ALL選択時はData属性は空白 startUp() //初期表示に戻す }else{ search_filter(group); //絞り込み //ボタン非表示 $('#more_btn').hide(); $('#close_btn').hide(); } });  });  function search_filter(group) {  $(listItem).removeClass(hideClass); // 値が空の場合はすべて表示 if(group === '') { return; } for (var i = 0; i < $(listItem).length; i++) { var itemData = $(listItem).eq(i).data('group'); if(itemData !== group) { $(listItem).eq(i).addClass(hideClass); } }  } </script> <script> var listContents = $("#entry_list_more li").length; startUp() //初期表示 //初期表示時とALL再選択されたときに実行 function startUp(){ $("#entry_list_more").each(function(){ var Num = 10; if(listContents > 10){ $(this).find('#more_btn').show(); }else{ $(this).find('#more_btn').hide(); } $(this).find('#close_btn').hide(); $(this).find("li:not(:lt("+Num+"))").hide(); $('#more_btn').click(function(){ Num +=5; $(this).parent().find("li:lt("+Num+")").slideDown(); if(listContents <= Num){ Num = 10; gtNum = Num-1; $('#more_btn').hide(); $('#close_btn').show(); $('#close_btn').click(function(){ $(this).parent().find("li:gt("+gtNum+")").slideUp(); $(this).hide(); $('#more_btn').show(); }); } }); }); } </script>

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

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

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

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

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

Lhankor_Mhy

2021/03/26 07:42

$('#more_btn').hide(); ↑これを削除すればいいのでは、と思うのですが、そういうことではなく?
rightbrain

2021/03/26 07:53

ご回答ありがとうございます。 ご指摘いただいた箇所を削除したところ、思うような動作になりました! あとは絞り込みを複数選択できるようにしたいと思います…!
Lhankor_Mhy

2021/03/26 07:59

$(listItem).removeClass(hideClass); ↑これを削除すればいいのでは、と思うのですが、そういうことではなく?
rightbrain

2021/03/26 08:24

引き続きご回答いただき、ありがとうございます。 $(listItem).removeClass(hideClass);を削除してみましたが、うまくいきませんでした… 複数選択はcheckboxのようなイメージです。 うまういく方法がございましたらお知恵を拝借させてください。
Lhankor_Mhy

2021/03/26 08:27

2か所ありますが、両方削除してもダメですか?
Lhankor_Mhy

2021/03/26 08:29

ああ、そうか。 もしかして、OR検索をしたいのでしょうか?
rightbrain

2021/03/26 08:35

そうですねOR検索です! 知識が乏しくどこをどう修正してよいやら…何か方法はありますでしょうか
Lhankor_Mhy

2021/03/26 08:37

おおむね全部書き直しですね!
rightbrain

2021/03/26 08:39

やはり今のままでは難しいのですね… ご丁寧に返信いただきありがとうございます!他の方法を検討してみたいと思います
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問