我有一个观点:
@app.route('/', methods=['GET', 'POST'])
@app.route('/index', methods=['GET', 'POST'])
@app.route('/index/<int:page>', methods=['GET', 'POST'])
def index(page=1):
posts = Post.query.paginate(page, 3, False).items
return render_template('index.html', posts=posts)
代码模板:
{% if posts %}
<ol>
{% for post in posts %}
<li>{{ post.title }}</li> | {{ post.text }} | {{ post.time }}</li>
{% endfor %}
</ol>
{% else %}
<h2>There is no posts</h2>
{% endif %}
{% if posts.has_prev %}<a href="{{ url_for('index', page=posts.prev_num) }}"><< Newer posts</a>{% else %}<< Newer posts{% endif %} |
{% if posts.has_next %}<a href="{{ url_for('index', page=posts.next_num) }}">Older posts >></a>{% else %}Older posts >>{% endif %}
问题在于它不会为我生成链接以查看更多帖子。
答案 0 :(得分:5)
.has_prev
和.has_next
是Pagination
instance的属性,但您要丢弃该实例。您传入视图的所有内容都是Pagination.items
属性。然后,您尝试仍然访问项目列表中的.has_prev
和.has_next
属性,并且那些属性不存在,因此Jinja2将这些属性解析为 undefined 。
传入Pagination
实例:
posts = Post.query.paginate(page, 3, False)
return render_template('index.html', posts=posts)
并调整模板:
{% if posts.items %}
<ol>
{% for post in posts.items %}
<li>{{ post.title }}</li> | {{ post.text }} | {{ post.time }}</li>
{% endfor %}
</ol>
{% else %}
<h2>There is no posts</h2>
{% endif %}
{% if posts.has_prev %}<a href="{{ url_for('index', page=posts.prev_num) }}"><< Newer posts</a>{% else %}<< Newer posts{% endif %} |
{% if posts.has_next %}<a href="{{ url_for('index', page=posts.next_num) }}">Older posts >></a>{% else %}Older posts >>{% endif %}