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

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

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

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

jQuery

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

Q&A

3回答

268閲覧

【jquery】forの第三引数について

marimon

総合スコア32

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2019/07/16 20:55

指定数ずつリストを分割したいです。

下記numの指定数ですが、2以外だとうまくいきません。

下記のように2なら2件ずつに分割されるのですが、34だとおかしくなります。(たとえば3なら<li>three</li>が消える)

理由と解決策があれば教えていただけませんでしょうか。

jquery

1<script> 2$(function(){ 3 const li = '<li>one</li>,<li>two</li>,<li>three</li>,<li>four</li>,<li>five</li>'; 4 const lis = li.split(',').map( x=>$(x) ); 5 const num = 2; // 2以外でも分割できるようにしたい 6 for( let i=0; i<lis.length; i+=num ){ 7 $('#hoge').append($('<div>').append($('<p>ttl</p>')).append($('<ul>').append( lis[i],lis[i+1])) ); 8 } 9}); 10</script> 11 12<div id="hoge"></div>

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

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

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

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

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

guest

回答3

0

javascript

1<script> 2$(function(){ 3 const li = '<li>1</li>,<li>2</li>,<li>3</li>,<li>4</li>,<li>5</li>,<li>6</li>,<li>7</li>'; 4 const lis = li.split(',').map( x=>$(x) ); 5 const num = 3; 6 for( let i=0; i<lis.length; i+=num ){ 7 $('#hoge').append($('<div>').append($('<p>ttl</p>')).append($('<ul>').append(Array(num).fill(null).map((x,y)=>lis[i+y])))); 8 } 9}); 10</script> 11 12<div id="hoge"></div>

投稿2019/07/17 00:36

yambejp

総合スコア114825

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

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

0

append( lis[i],lis[i+1], lis[i+2])))

投稿2019/07/16 22:23

papinianus

総合スコア12705

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

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

0

こんにちは

以下の回答は、 num が変わっても、<ul> にappendする(最大)num個の <li> を作るコードは変えなくてもよいようにするためのものです。

配列lisの部分配列で、開始インデクスがi で要素の数が最大num個となるものを、以下で作成できます。

javascript

1lis.slice(i, i+num)

上記を <ul> にappendすればよいかと思います。

以下、サンプルです。

  

  

 

以上参考になれば幸いです。

投稿2019/07/16 23:57

jun68ykt

総合スコア9058

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問