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

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

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

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

jQuery

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

Q&A

解決済

1回答

476閲覧

絞り込み機能について

miyabeam

総合スコア16

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2019/04/25 02:00

編集2019/04/25 02:06

やりたいこと

jQueryを使って、チェックボックスを使っての絞り込み表示を実装したいです。
例えばtypeAcategoryanimalにチェックが入っていた時、どちらの条件も満たした配列としたいです。
またcategoryanimalplantなど同一属性内で複数チェックがあった時、animalあるいはplantどちらかの条件を満たした配列としたいです。
現状typeでの絞り込みまで完成しており、type内で複数チェックがあった時の処理は未実装です。

HTML

1<div class="is-type"> 2 <h2>タイプでの絞り込み</h2> 3 <input type="checkbox" name="type" value="A"> A 4 <input type="checkbox" name="type" value="B"> B 5 <input type="checkbox" name="type" value="C"> C 6</div> 7 8<div class="is-type"> 9 <h2>カテゴリでの絞り込み</h2> 10 <input type="checkbox" name="category" value="animal"> animal 11 <input type="checkbox" name="category" value="plant"> plant 12</div> 13 14<ul class="is-list"></ul>

JavaScript

1// アイテムの情報 2const itemList = [ 3 { type: 'A', category: 'animal' }, 4 { type: 'B', category: 'plant' }, 5 { type: 'C', category: 'animal' } 6] 7 8// HTMLの生成 9const createItem = list => { 10 const listObject = $('.is-list'); 11 let listHTML = ''; 12 13 if (list.length > 0) { 14 $(list).each((index, item) => { 15 listHTML += `<li>` 16 listHTML += `<p>${ item.type }${ item.category }です</p>` 17 listHTML += `</li>` 18 }); 19 } 20 21 listObject.html(listHTML); 22} 23 24// 絞り込み表示 25const filteredItem = () => { 26 let newItemList = []; 27 28 createItem(itemList); 29 30 $('.is-type input').on('change', () => { 31 const chekedItems = $('.is-type input:checked'); 32 33 newItemList = itemList.filter(item => item.type === chekedItems.val()); 34 createItem(newItemList); 35 }); 36}

困っていること

同一属性内で複数チェックがあった時にいずれかの条件を満たした配列を作るにはどうすればいいかわからず困っております。。
また現状ではtypeでの絞り込みまでですが、ここからcategoryでの絞り込みを追加した時にtypecategoryどちらの条件も満たした配列を作るにはどうしたらいいかわからない状況です。
よろしくお願いします。

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

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

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

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

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

Lhankor_Mhy

2019/04/25 02:23

&& を使えばよさそうに思うのですが、ダメですか?
guest

回答1

0

ベストアンサー

こんな感じです

javascript

1<script> 2$(()=>{ 3 $('.is-type :checkbox').on('change',()=>{ 4 const types=$('[name=type]:checked').map((x,y)=>$(y).val()).get(); 5 const categories=$('[name=category]:checked').map((x,y)=>$(y).val()).get(); 6 const itemList = [ 7 { type: 'A', category: 'animal' }, 8 { type: 'B', category: 'plant' }, 9 { type: 'C', category: 'animal' } 10 ]; 11 $('.is-list').empty(); 12 itemList 13 .filter(x=>$.inArray(x.type,types)>-1 && $.inArray(x.category,categories)>-1) 14 .forEach(x=>{ 15 $('.is-list').append($('<li>').append($('<p>').text(`${x.type}${x.category }です`))); 16 }); 17 }).eq(0).trigger('change'); 18}); 19</script> 20 21 22<div class="is-type"> 23 <h2>タイプでの絞り込み</h2> 24<label> <input type="checkbox" name="type" value="A"> A</label> 25<label> <input type="checkbox" name="type" value="B"> B</label> 26<label> <input type="checkbox" name="type" value="C"> C</label> 27</div> 28 29<div class="is-type"> 30 <h2>カテゴリでの絞り込み</h2> 31<label> <input type="checkbox" name="category" value="animal"> animal</label> 32<label> <input type="checkbox" name="category" value="plant"> plant</label> 33</div> 34 35<ul class="is-list"></ul>

投稿2019/04/25 03:37

yambejp

総合スコア114769

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

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

miyabeam

2019/04/27 15:22

なるほど… 複数チェックには `map` で配列を作っておいて、 `filter` で絞り込めばいいんですね! ES6勉強し始めだったので大変参考になりました。ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問