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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Lodash

Lodashは、JavaScriptのユーティリティライブラリ。Underscoreの派生ライブラリで、配列・オブジェクトの操作に便利です。また、コードの可読性も高めることができます。

JavaScript

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

Q&A

解決済

1回答

1332閲覧

Vueでチェックボックスによる絞り込み表示

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Lodash

Lodashは、JavaScriptのユーティリティライブラリ。Underscoreの派生ライブラリで、配列・オブジェクトの操作に便利です。また、コードの可読性も高めることができます。

JavaScript

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

0グッド

0クリップ

投稿2018/06/22 08:41

編集2018/06/22 08:47

現在、JavaScriptとVueの勉強中で、チェックボックスによる絞り込み表示をしたいと考えております。

チェックボックスの tag1 を一つだけチェックした場合は tag1 に該当するもの、tag1tag2 のように複数チェックした場合は、tag1 または tag2 に該当するものだけを表示したいです。

チェックボックスを1つだけ選択したときは問題なく絞り込み表示されますが、複数選択すると表示されません(><)

matchedの絞り込みするメソッドの記述に問題があるのでしょうか?

items.tagscheckedNames の配列同士の項目が部分一致するか確かめる方法がわからないため、toString()で文字列にして lodashライブラリ の _.includes を使って判定するようにしました。

複数選択しても絞り込み表示される方法を教えてくださいm(__)m

html

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4<meta charset="utf-8"> 5<title>test</title> 6</head> 7<style> 8body { 9 font-size: 14px; 10} 11.list { 12 max-width: 800px; 13 margin: 0; 14 padding: 0; 15 display: flex; 16 flex-wrap: wrap; 17} 18.list_item { 19 width: 33.333%; 20 margin: 0; 21 padding: 15px; 22 box-sizing: border-box; 23 border-right: 1px solid #ccc; 24 border-bottom: 1px solid #ccc; 25 list-style: none; 26} 27.list_item:nth-child(1), 28.list_item:nth-child(2), 29.list_item:nth-child(3) { 30 border-top: 1px solid #ccc; 31} 32.list_item:nth-child(3n-2) { 33 border-left: 1px solid #ccc; 34} 35 36</style> 37<body> 38 39<div id="app"> 40 41 <select name="" v-model="selected"> 42 <option value="新着順">新着順</option> 43 <option value="人気順">人気順</option> 44 </select> 45 46 <p>選択中:{{ selected }}</p> 47 48 <br> 49 50 <label><input type="checkbox" name="tag" value="all" v-model="checkedNames"> all</label><br> 51 <label><input type="checkbox" name="tag" value="tag1" v-model="checkedNames"> tag1</label><br> 52 <label><input type="checkbox" name="tag" value="tag2" v-model="checkedNames"> tag2</label><br> 53 <label><input type="checkbox" name="tag" value="tag3" v-model="checkedNames"> tag3</label><br> 54 <label><input type="checkbox" name="tag" value="tag4" v-model="checkedNames"> tag4</label><br> 55 56 <p>選択中:{{ checkedNames }}</p> 57 58 <ul class="list"> 59 <li v-for="item in sorted" class="list_item"> 60 <h3><a :href="item.link">{{ item.title }}</a></h3> 61 <p>{{ item.date }}</p> 62 <p>{{ item.text }}</p> 63 <ul v-for="tag in item.tags"> 64 <li>{{ tag }}</li> 65 </ul> 66 <p>表示数 {{ item.view }}</p> 67 </li> 68 </ul> 69 70</div> 71 72<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.10/lodash.min.js"></script> 73<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> 74<script> 75new Vue({ 76 el: '#app', 77 data: { 78 items: [ 79 { 80 title: 'タイトル:あああああああああ', 81 text: '本文:ああああああああああああああああああああああ', 82 tags: ['tag2', 'tag3'], 83 link: 'http://example.com', 84 date: '2018-06-20 00:00:00', 85 view: 32 86 }, 87 { 88 title: 'タイトル:いいいいいいいいいい', 89 text: '本文:いいいいいいいいいいいいいいいいいいいいい', 90 tags: ['tag1', 'tag2', 'tag3', 'tag4'], 91 link: 'http://example.com', 92 date: '2018-06-19 00:00:00', 93 view: 89 94 }, 95 { 96 title: 'タイトル:ううううううううう', 97 text: '本文:うううううううううううううううううううううううう', 98 tags: ['tag1', 'tag2'], 99 link: 'http://example.com', 100 date: '2018-06-21 00:00:00', 101 view: 12 102 }, 103 { 104 title: 'タイトル:えええええええ', 105 text: '本文:ええええええええええええええええええええ', 106 tags: ['tag2', 'tag4'], 107 link: 'http://example.com', 108 date: '2018-06-02 00:00:00', 109 view: 9 110 }, 111 { 112 title: 'タイトル:おおおおおお', 113 text: '本文:おおおおおおおおおおおおおおおおおおおおおおおおおおお', 114 tags: ['tag4'], 115 link: 'http://example.com', 116 date: '2018-06-12 00:00:00', 117 view: 4 118 }, 119 ], 120 selected: '新着順', 121 checkedNames: ['all'] 122 }, 123 computed: { 124 125 matched: function() { 126 127 return this.items.filter(function(el) { 128 129 var result = ''; 130 131 if( _.includes(this.checkedNames, 'all') ) { 132 133 return true; 134 135 } else if( _.includes(el.tags, this.checkedNames.toString())) { 136 137 result = true; 138 139 } else { 140 141 result = false; 142 143 } 144 return result; 145 146 }, this) 147 148 }, 149 sorted: function() { 150 151 if( this.selected === '新着順' ) { 152 153 return _.orderBy( this.matched, 'date', 'desc' ) 154 155 } else if( this.selected === '人気順' ) { 156 157 return _.orderBy( this.matched, 'view', 'desc' ) 158 159 } else { 160 return this.matched; 161 } 162 } 163 } 164}); 165</script> 166 167</body> 168</html>

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

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

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

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

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

guest

回答1

0

ベストアンサー

matchedの部分を以下に変えてみてください

javascript

1matched: function() { 2 return this.items.filter(el => { 3 if(_.includes(this.checkedNames, 'all')) return true; 4 else if(_.intersection(this.checkedNames, el.tags).length > 0) return true; 5 else return false; 6 }) 7},

みそは_.intersection()、つまり、積集合をつかっているところですね。
[1, 2, 3]と[2, 4, 6]の積集合は[2]っていうやつです。
積集合の配列が0より大きければ、何かがマッチしたと考えられますよね。

投稿2018/06/22 09:40

kamome283

総合スコア52

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

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

退会済みユーザー

退会済みユーザー

2018/06/22 09:51 編集

おおお!表示されました!!! intersectionで配列の積集合を取得した結果、配列があれば部分一致してるという手法なんですね!神! 勉強になりました。ありがとうございますm(__)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問