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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Slim

SlimはPHPアプリケーションを開発するための軽量なマイクロフレームワークです。

Q&A

1回答

2813閲覧

ul, liのslimコードで、ループの途中にulを挟みたいです。愚直にすると、重複コードが気になってため困っております。

qaz3330

総合スコア113

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Slim

SlimはPHPアプリケーションを開発するための軽量なマイクロフレームワークです。

0グッド

1クリップ

投稿2016/12/14 01:24

次のようなulタグliタグで構成されるリストのhtmlがあります。

ul - 6.times do li span hoge

liをループで6つ生成しているのですが、
3回目のループの際に、ulを挟み、次のような結果にさせたいです。

ul li span hoge li span hoge li span hoge ul li span hoge li span hoge li span hoge

私の実装

このようにすれば実装はできるのですが、ul, li, spanのコードが重複しているため、すごく気になります。
その対策として、partialを使って、共通テンプレートにして対応というのも考えられますが、
もっときれいに実装出来ないかと思い質問しました。

※ 今回のコードではli配下が span hoge だけなのでそこまで重複が気になりませんが、
実際のコードは li 配下には結構処理が書かれております。
li配下の中にもpartialがあったりするので、ul, li, spanのコードもpartialにすると、さらにpartialの階層が深くなってしまい避けたいなと思ってます。

ul - 6.times do |no| - if no == 2 ul li span - else li span hoge

理想

実際には、これではだめなんですが、
3回目のときだけ、liタグの前に、ulタグをネストさせるような方法をとれないかと思っております。

ul - 6.times do |no| - if no == 2 ul li span

よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ul生成自体もループで回してしまってはどうでしょうか。

- 2.times do |outer| ul - 3.times do |inner| li span hoge

この形に合わせるために一次元の長い配列を二次元に切り出したい、というのでしたら、Enumerable#each_sliceるりま)を使えます。

投稿2016/12/14 02:41

maisumakun

総合スコア145121

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

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

qaz3330

2016/12/14 03:20

ご回答有難う御座います。 今回 6.timesとしており、私のミスではありますが、 実際のhtmlは railsのヘルパーである f.fields_for を使い、6回ループさせているような構成になっております。 そのため、 2timesでわけることができません。。。 説明不足で失礼しました。 each_sliceをつかえば、上手くできそうですので、一度試してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問