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

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

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

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

jQuery

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

Q&A

2回答

263閲覧

for文でn回ずつループさせ、タブ出し分けを2つ設置させたい

ysfree14

総合スコア19

JavaScript

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

jQuery

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

0グッド

2クリップ

投稿2019/09/03 03:56

編集2019/09/03 03:56

for文を使ってjsonの要素を抜き出しています。
フィルタリングで要素の出し分けを行い、下記コードにて8個ずつ表示させている状態です。
(もっと見るボタンをクリックでさらに8件ずつ表示していく)

参考にしたのはこちらのサイトです。
http://the-zombis.sakura.ne.jp/wp/blog/2014/01/03/post-2094/

フィルタリングが1箇所の場合は思い通りの動作ができたのですが、2つの異なったjsonを読み込み、フィルタリングもそれぞれ2箇所に分けて設置したい場合、どのように記述すればよいのでしょうか?

id="boxes"とid="select-boxes"にそれぞれフィルタリングを設置したいと考えています。
よろしくお願い致します。

html

1<form class="original-filter"> 2  <label class="btn-on"> 3    <input type="radio" name="list" value="all" checked="checked"> 4    <span>All</span> 5  </label> 6  <label> 7    <input type="radio" name="list" value="new"> 8    <span>new</span> 9  </label> 10  <label> 11    <input type="radio" name="list" value="re"> 12    <span>re</span> 13  </label> 14</form> 15 16<div id="boxes" class="boxes cf"></div> 17<div class="original-tab-more-btn">もっと見る</div> 18 19<!--追加するフィルタリング--> 20<form class="select-filter"> 21  <label class="btn-on"> 22    <input type="radio" name="list" value="all" checked="checked"> 23    <span>All</span> 24  </label> 25  <label> 26    <input type="radio" name="list" value="s-new"> 27    <span>new</span> 28  </label> 29  <label> 30    <input type="radio" name="list" value="s-re"> 31    <span>re</span> 32  </label> 33</form> 34 35<div id="select-boxes" class="boxes cf"></div> 36<div class="select-tab-more-btn">もっと見る</div>

jQuery

1$(function(){ 2 3 //変数設定 4 var $boxes = $("#boxes"); 5 var alldata = []; //ここはすべてのデータを保持しておく配列 6 var filterdata = []; //フィルターを掛けたデータを保持する配列 7 8 //最初に読み込んだ時に発生する関数 9 $.getJSON('jsonのソース',init); 10 11 function init(data) { 12   //全データを保持しておく 13   alldata = data; 14   //とりあえず全データを代入しておく 15   filterdata = alldata; 16   //データを表示させる 17   display(0); 18 } 19  20 const MAX_DISPLAY_COUNT = 8; 21 22 //表示させるための関数 23 function display(startIndex) { 24 25 $('.original-tab-more-btn').show(); 26 for (var i = startIndex; i < startIndex + MAX_DISPLAY_COUNT; i++) { 27 if(!filterdata[i]){ 28 $('.original-tab-more-btn').hide(); 29 return; 30 } 31 $('<div class="original-tab-elm"><a href="' + filterdata[i].url + '" target="_top" class="block"><div class="product-img img-col1"><img src="' + filterdata[i].img + '" alt="" id="product-img"></div><div class="label-wrap"><p class="img-label' + filterdata[i].labelName + '">' + filterdata[i].dateText + '</p><p class="img-label' + filterdata[i].labelName2 + '">' + filterdata[i].dateText2 + '</p></div><p class="price-text">' + filterdata[i].price + '</p></a></div>').appendTo($boxes); 32 } 33 }  34  35 let currentDisplayCount = 0; 36 37 //ラジオボタンが変わった時にフィルタリングする関数 38 $('.original-filter input:radio').change(function(){ 39 40 $boxes.empty(); 41 42 //チェックボタンの状況によってフィルタリングする 43 var cate=$(this).val(); 44 //フィルターの配列をいったん空っぽにする 45 filterdata=[]; 46 47 if(cate==="all"){//allが選択されたら全データを保持 48 filterdata=alldata; 49 50 }else{ 51 filterdata=$.grep(alldata,function(n){ 52 return n.category===cate; 53 }); 54 } 55 56 currentDisplayCount = 0; 57 display(currentDisplayCount); 58 59 }); 60 61 //もっと見るで要素を追加 62 $('.original-tab-more-btn').click(function () { 63 currentDisplayCount += MAX_DISPLAY_COUNT; 64 display(currentDisplayCount); 65 }); 66 67});

json

1[ 2 3{ 4"category": "re", 5"url": "", 6"img": "", 7"labelName": "", 8"dateText": "", 9"labelName2": "", 10"dateText2": "", 11"price": "" 12}, 13 14{ 15"category": "re", 16"url": "", 17"img": "", 18"labelName": "", 19"dateText": "", 20"labelName2": "", 21"dateText2": "", 22"price": "" 23}, 24 25]

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

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

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

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

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

guest

回答2

0

基本的なeachメソッドで解決すると思います。双方に同じクラスを指定しておき、jsonデータの回収用にdataメソッドで値を取得しておくようにします。

<form class="select-filter" data-jsonidx="0">   <label class="btn-on">     <input type="radio" name="list" value="all" checked="checked">     <span>All</span>   </label>   <label>     <input type="radio" name="list" value="new">     <span>new</span>   </label>   <label>     <input type="radio" name="list" value="re">     <span>re</span>   </label> </form> <div id="boxes" class="boxes cf"></div> <div class="original-tab-more-btn">もっと見る</div> <!--追加するフィルタリング--> <form class="select-filter" data-jsonidx="1">   <label class="btn-on">     <input type="radio" name="list" value="all" checked="checked">     <span>All</span>   </label>   <label>     <input type="radio" name="list" value="s-new">     <span>new</span>   </label>   <label>     <input type="radio" name="list" value="s-re">     <span>re</span>   </label> </form>

それからeachメソッドで任意の回数ループさせれば、同じ処理を繰り返し行えます。またイベントトリガーもeachメソッドで任意のラジオボタンが選択されるようにすれば行けるのではないかと思います。
jsonはインデックスさえ取得できればいいので、他にもいい方法はあると思います。

JQuery

1/*以上、前略*/ 2$.getJSON('jsonのソース',init); 3 4 function init(data) { 5   //全データを保持しておく 6   alldata = data; 7   //とりあえず全データを代入しておく 8   filterdata = alldata; 9   //データを表示させる 10   display(0); 11 } 12 13/*以下を書き加える*********************/ 14let json_idx; 15$('.select-filter').each(function(){ 16 $(this).find('input[type=radio]').val(); 17 json_idx = $(this).data('jsonidx'); //jsonのインデックスを埋め込んだデータから取得 18 display(json_idx); //任意のフィルターを行う関数 19}) 20 21// 22let currentDisplayCount = 0; 23 24 //ラジオボタンが変わった時にフィルタリングする関数 25$('.original-filter input:radio').each(function(){ 26 $(this).on("click",function(){ 27 $boxes.empty(); 28 //チェックボタンの状況によってフィルタリングする 29 var cate=$(this).val(); 30 //フィルターの配列をいったん空っぽにする 31 filterdata=[]; 32 33 if(cate==="all"){//allが選択されたら全データを保持 34 filterdata=alldata; 35 }else{ 36 filterdata=$.grep(alldata,function(n){ 37 return n.category===cate; 38 } 39 }) 40}) 41/*以下省略*/ 42

すぐに動作確認ができないのですが、これで調整してみてください。

投稿2019/09/03 07:05

編集2019/09/03 07:07
FKM

総合スコア3633

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

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

ysfree14

2019/09/03 10:04

ご回答ありがとうございます。 最初ページを読み込んだ際に、 id="boxes" id="select-boxes" 上記2か所にそれぞれ最新の8つを表示させるにはどうすればいいのでしょうか?
FKM

2019/09/03 12:07

同じクラス名にしておいて、eachメソッドで順繰りに値を取得する、同じ方法で行けるはずです 一回だと行けるってことなら、2回でも3回でも行けるはずですから。 その際、同じクラス名にしておくことです。クラス名を別にしてしまうと別のDOMとして認識してしまいますので。
ysfree14

2019/09/09 02:29

ご回答ありがとうございます。 json_idx = $(this).data('jsonidx'); //jsonのインデックスを埋め込んだデータから取得 上記の部分の処理が理解できておりません、、 jsonも1つにまとめ、インデックスを追加するということなのでしょうか?
guest

0

jsonファイルは一定の次元の配列になって格納されます。それを引き出すのですが、そのためにはインデックスを0,1と変えていく必要があると思います。

jQueryのdataメソッドを任意の値を格納、取得したいときに使うので、そこに順番に0,1と格納しておくだけですよ。そんな回りくどいことしなくても普通に変数で代入してもいいとは思いますけど。

元の式にdisplay(0);というのがあると思いますが、この0というのはJSONのインデックスを示すものです。

投稿2019/09/09 05:02

FKM

総合スコア3633

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

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

ysfree14

2019/09/09 06:20

ご回答ありがとうございます。 引き続き調整してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問