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

首页列表显示全部问答:

  1. 将数据库查询结果传递到前端页面 Question.query.all()
  2. 前端页面循环显示整个列表。
  3. 问答排序
@app.route('/')
def index():
    context={
        'questions':Question.query.order_by('-creat_time').all()
    }
    return render_template('index.html',**context)
<ul class="list-group">
        {% for foo in questions %}
            <li style="padding-left: 0px;padding-right: 10px;box-shadow: #cccccc" 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) }}" class="title">{{foo.title}}</a>
                <br>
                <span class="badge">{{foo.creat_time}}</span>
                <p class="detail">{{foo.detail}}</p>
             </li>
        {% endfor %}
    </ul>

 

完成问答详情页布局:

  1. 包含问答的全部信息
  2. 评论区
  3. 以往评论列表显示区。
{% extends'base.html' %}
{% block title %}
    问答详情
{% endblock %}

{% block head %}
     <!-- 引入 Bootstrap -->
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
{% endblock %}

{% block main %}
<h1>问题详情</h1>
<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <h3 class="text-center">
                title
            </h3>
            <p class="text-center">
                 detail
            </p>
            <form role="form">
                <div class="form-group">
                     <label for="exampleInputEmail1">Write down your answer~~</label><input type="email" class="form-control" id="exampleInputEmail1" />
                </div>
                 <button type="submit" class="btn btn-default">Submit</button>
            </form>
        </div>
    </div>
</div>
{% endblock %}
  1. 在首页点击问答标题,链接到相应详情页。
@app.route('/detail/<question_id>')
def detail(question_id):
    quest = Question.query.filter(Question.id == question_id).first()

    return render_template('detail.html',quest = quest)

 

转载于:https://www.cnblogs.com/qingting/p/7955732.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值