繁体   English   中英

Python flask jinja2模板变量上下文。 无法呈现变量

[英]Python flask jinja2 template variable contexts. Can't render variables

编辑:简化了for循环,使其更易于说明问题,但问题仍然相同。

我正在尝试渲染一瓶jinja2模板,以从图像名称列表中呈现图像轮播。 images变量正在调试器中显示,当我逐步执行它时似乎在循环遍历,但由于某种原因它没有呈现。

# flask app file
@app.route('/results', methods=['POST', 'GET'])
@login_required
def newpage(page=1):
    """
    Renders search page
    """
    form = genus_form()
    user = current_user
    if request.method == 'POST':
        if form.validate_on_submit():
            gen = Genus.query.filter(Genus.genus_name.like(form.genus.data)).first()
            spec = Species.query.filter_by(GID=gen.GID).first()
            images = Images.query.filter_by(UID=spec.UID).all()
            if images:
                images = [i.FileName for i in images]
            form.genus.data = ''
            render_template('results.html', form=form, images=images)
        else:
            return render_template('results.html', form=form)
    return render_template('results.html', form=form)

这是jinja模板中的相关部分:

{% extends 'base.html' %}
{% block title %} WCTC Image Review {% endblock %}
{% block scripts %}
    {{ super() }}
<script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<script>

$(document).ready(function () {

    $("#genus").autocomplete({
        delay: 100,
        source: function (request, response) {

            // Suggest URL
            var suggestURL = "{{ url_for('autocomplete') }}?term=%QUERY";
            suggestURL = suggestURL.replace('%QUERY', request.term);

            // JSON Request
            $.ajax({
                method: 'GET',
                dataType: 'json',
                jsonCallback: 'jsonCallback',
                url: suggestURL
            })
            .success(function(data){
                response(data);
            });
        }
    });
});

$('#myCarousel').carousel({
  interval: 40000
});

$('.carousel .item').each(function(){
  var next = $(this).next();
  if (!next.length) {
    next = $(this).siblings(':first');
  }
  next.children(':first-child').clone().appendTo($(this));

  if (next.next().length>0) {
      next.next().children(':first-child').clone().appendTo($(this)).addClass('rightest');

  }
  else {
      $(this).siblings(':first').children(':first-child').clone().appendTo($(this));

  }
});

</script>
{% endblock %}
{% block content %}

<div>
    <form action="/results" method="POST" id="search">
        <fieldset>
            <div>
                {{ form.genus(placeholder="Genus") }}
            </div>
            <div>
                <button type="submit" class="btn btn-default">Submit</button>
            </div>
        </fieldset>
    </form>
</div>
{% if images %}
                {% for filename in images %}
                         <div>
                             {{ filename }}
                         </div>
                {% endfor %}
{% endif %}
{% endblock %}

任何帮助将不胜感激。

添加return到此行:

return render_template('results.html', form=form, images=images)

模板应如下所示:

{% if images %}
    {% for filename in images %}
        <div>
          <img src="{{ filename }}">
        </div>
    {% endfor %}
{% endif %}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM