首页列表显示全部问答,完成问答详情页布局

1.首页列表显示全部问答:

  a.将数据库查询结果传递到前端页面 Question.query.all()

  b.前端页面循环显示整个列表。

  c.问答排序

@app.route('/')
def index():
    context = {
        'questions': Question.query.order_by('-creat_time').all()
    }
    return render_template('base.html',**context)

2.完成问答详情页布局:

  a.包含问答的全部信息

  b.评论区

  c.以往评论列表显示区。

{% extends 'base.html' %}
{% block title %}问答详情{% endblock %}
{% block main %}
    <div class="page-header">
       <h3>题目:{{ questions.title }}<br><small>作者:{{ questions.author }} 发布时间:{{ questions.create_time }}</small></h3>
    </div>
    <p class="lead">detail{{ questions.detail }}</p>
    <hr>
    <form action="{{ url_for('questions') }}" method="post">
    <div class="form-group">
        <textarea name="new_comment" class="form-control" rows="3" id="new_comment" placeholder="write your comment"></textarea>
    </div>
    <button type="submit" class="btn btn-default">发送</button>
    </form>
    <ul class="list-group" style="margin: 10px"></ul>

{% endblock %}

3.在首页点击问答标题,链接到相应详情页。

{% block main%}
<p>{{user}} context</p>
<ul class="list-group">
{% for foo in questions %}
    <li class="list-group-item">
        <span class="glyphicon glyphicon-leaf" aria-hidden="true"></span>
        <a href="#">{{ foo.author.username }}</a>
        <br>
        <a href="{{ url_for('detail',question_id=foo.id) }}">{{ foo.title }}</a>
        <span class="badge">{{ foo.creat_time }}</span>
        <p style="color:black">{{ foo.detail }}</p>
    </li>
{% endfor %}
</ul>
{% endblock %}
原文地址:https://www.cnblogs.com/cch-1007/p/7944419.html