完成评论功能

完成评论功能

    1. 定义评论的视图函数
      @app.route('/comment/',methods=['POST'])
      def comment():
      读取前端页面数据,保存到数据库中
      @app.route('/comment/',methods=['GET','POST'])
      @log_re
      def comment():
          if request.method == 'GET':
              return render_template("detail.html")
          else:
              comment = request.form.get('new_comment')
              ques_id = request.form.get('question.id')
              author_id = User.query.filter(User.username == session.get('user')).first().id
              comm = Comment(author_id=author_id,question_id=ques_id,detail=comment)
              db.session.add(comm)  # 保存到数据库
              db.session.commit()  # 提交
              return redirect(url_for('detail',question_id =ques_id))

       

    2. 用<input type="hidden" 方法获取前端的"question_id" 
    3. 显示评论次数
    4. 要求评论前登录
    5. 尝试实现详情页面下的评论列表显示
      {% extends 'base.html' %}
      {% block title %}
          问答详情页
      {% endblock %}
      {% block head %}
          <link type="text/css" rel="stylesheet" href="../static/css/detail.css">
      {% endblock %}
      {% block main %}
          <ul class="list">
          <div class="page-header">
              <h3>{{ ques.title }}<br></h3>
              <small>{{ ques.author.username }}</small>
          </div>
              <p class="answer" style="text-indent: 18px">{{ ques.detail }}</p>
              <hr>
              <form action="{{ url_for('comment') }}" method="post">
              <span class="badge">{{ ques.creat_time }}</span>
              <a href="a">回复♥</a>
              <a href="b">送礼</a>
              <div>
                  <textarea name="new_comment" class="form-control" rows="3" id="new-comment" placeholder="我也说一句..."></textarea>
                  <input name="question_id" type="hidden"   value="{{ ques.id }}" >
              </div>
              <button type="submit" class="btn btn-default">发送</button>
              </form>
              <div class="pinglunqu">
              <h4>评论:({{ ques.comments|length }})</h4><br>
              <ul class="list1">
                  {% for ques in ques.comments %}
                  <li class="list2">
                     <img style="width: 30px" src="{{ url_for('static',filename='../static/images/friends.jpg') }}" >
                      <a href="#">{{ ques.author.username }}</a>
                      <span class="badge">{{ ques.creat_time }}</span><br>
                      <p class="pinglun">评论:{{ ques.detail }}</p><br>
                  </li>
                  {% endfor %}
          </ul>
              </div></ul>{% endblock %}

       

posted @ 2017-12-08 15:12 林丹宜 阅读( ...) 评论( ...) 编辑 收藏
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值