Рендеринг изображения в левой и правой части экрана поочередно - PullRequest
1 голос
/ 24 февраля 2020

Я хочу визуализировать изображение в левой и правой части экрана поочередно, динамически в шаблоне django. Я не уверен, как его визуализировать, например, если для счетчика l oop он равен 0, изображение должно появиться в левой части экрана, для следующей итерации изображение должно отображаться справа и т. Д.

Это мое требование

Это то, что я достиг

Код ниже HTML

{% block content %}

<!-- Banner -->
<div class="banner">
 <div class="container-fluid banner-content">
  <h3>{{page.banner_head}}</h3>
  {{page.banner_desc|richtext}}
 </div>
</div>

<section class="solution-section">
 <div class="container-fluid">
  {% for i in page.solutions.all %}
    <div class="row pb-5">

      <!-- Image -->
      <div class="col-md-6">
        <div class="solution-image">
          <figure class="text-center">
            <h6>{{ i.img_text }}</h6>
          </figure>
          {% image i.sol_img original as img %}
          <img src="{{ img.url }}" class="img-fluid solution-index-image" alt="{{ img.alt }}">
        </div>
      </div>

      <!-- Text -->
      <div class="col-md-6 solution-desc">
        <h5>{{i.sol_head}}</h5>
          {{i.sol_desc|richtext}}
        <a href="{{i.sol_link}}" class="btn btn-md solution-btn">learn more</a>
      </div>
    </div>
  {% endfor %}
</div>
</section>


{% endblock %}

models.py

class SolutionPage(Page):
banner_head = models.CharField('Banner Title', blank=True, max_length=255)
banner_desc = RichTextField('Banner Description', blank=True)

content_panels = Page.content_panels + [
    MultiFieldPanel([
        FieldPanel('banner_head'),
        FieldPanel('banner_desc'),
    ], heading='Banner Section'),

    InlinePanel('solutions', label='Solution Details'),

]

class Solution(Orderable):
sol_img = models.ForeignKey(
    'wagtailimages.Image',
    null = True,
    blank = True,
    on_delete = models.SET_NULL,
    related_name = '+',
    verbose_name = 'Solution Image',
)
img_text = models.CharField('Image Text', blank=True, max_length=255)
sol_head = models.CharField('Solution Heading', max_length=100, blank=True)
sol_desc = RichTextField('Solution Description', blank=True)
sol_link = models.CharField('Button Link', max_length=255, blank=True)
page = ParentalKey('SolutionPage', related_name='solutions')

panels = [
    ImageChooserPanel('sol_img'),
    FieldPanel('img_text'),
    FieldPanel('sol_head'),
    FieldPanel('sol_desc'),
    FieldPanel('sol_link')
]

1 Ответ

1 голос
/ 24 февраля 2020

Отметьте нечетное / четное в шаблоне с помощью {% if forloop.counter|divisibleby:"2" %}.

...