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

本文详细介绍了如何使用Flask框架实现一个问答网站的前后端交互,包括首页问答列表的展示、问答详情页的布局设计及评论功能。通过数据库查询,前端能够循环显示所有问答,并按创建时间排序,同时,点击问答标题可以跳转至详情页。
摘要由CSDN通过智能技术生成
  1. 首页列表显示全部问答:
    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="news-list">
              {% for foo in wenda %}
              <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>
                  <br>
                  <span class="badge" >{{ foo.creat_time }}</span>
                  <p style=" padding: 0px; line-height: 1.8; color: rgb(128, 0, 0);">">{{ foo.detail }}</p>
              </li>
              {%  endfor %}
      
          </ul>

       

  2. 完成问答详情页布局:
    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 %}

       

  3. 在首页点击问答标题,链接到相应详情页。
    @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/Green-/p/7986116.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值