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

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

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

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

Q&A

解決済

1回答

721閲覧

jQueryのwrapAllを複数要素にて使いまわしたい

nana7777

総合スコア7

jQuery

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

0グッド

0クリップ

投稿2023/04/17 03:48

実現したいこと

html

1<div class="wrap"> 2<ul> 3<li>リストA</li> 4<li>リストA</li> 5<li>リストA</li> 6...リストA8個 7</ul> 8</div> 9 10<div class="wrap"> 11<ul> 12<li>リストB</li> 13<li>リストB</li> 14<li>リストB</li> 15...リストB12個 16</ul> 17</div>

上記のように同じクラス名を持つボックス内(.wrap内)のリストを6個ずつ区切ってul.class-nameで囲み直したいのですが、リストAのul2個目にリストBの最初の4個が入ってしまいます。(リストA2個+リストB4個の合計6個をulで囲んでしまう)

リストAとBが干渉し合わずに、それぞれの.wrap内だけで計算してリストで囲みたいです。

前提

現在のjQueryコード

jQuery

1const listWrap = $(".wrap"); 2const list = $(".wrap li"); 3 4listWrap.each(function() { 5do { 6 listWrap.children("li:lt(6)").wrapAll('<ul class="class-name"></ul>') 7 } while(listWrap.children("li").length); 8});

試したこと

Shopifyのテーマで使用する予定なので、Shopifyのテンプレート側で.wrapに個別にidをつけて

jQuery

1const listWrap = $(".wrap"); 2const list = $(".wrap li"); 3 4listWrap.each(function() { 5 let boxid = $(this).attr('id'); 6 let boxidSelector = $("#"+boxid); 7 list.unwrap(); 8 do { 9 boxidSelector.children("li:lt(6)").wrapAll('<ul class="sclass-name"></ul>') 10 } while(boxidSelector.children("li").length); 11});

としてみたのですが、こちらはulで囲んでくれなくなりました。

よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

js

1listWrap.each(function() { 2do { 3 listWrap.children("li:lt(6)").wrapAll('<ul class="class-name"></ul>') 4 } while(listWrap.children("li").length); 5});

せっかく each() で処理しているのに、中で listWrap を使ってはeach() の意味がありません。function() {の中では listWrap の代わりに $(this) を使いましょう。

投稿2023/04/17 04:06

int32_t

総合スコア21423

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

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

nana7777

2023/04/17 04:39

早速のご回答ありがとうございます!確かにそうですね…!最初は一つだけの予定だったので、idをつけてたのですが、idからクラス名に変更してそのまま全然気づいていませんでした!あっという間に解決しましたー!かなり遠回りしてました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.40%

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

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

質問する

関連した質問