从首页问答标题到问答详情页

主PY文件写视图函数,带id参数。 

@app.route('/detail/<question_id>')
def detail(question_id):
    quest = 
    return render_template('detail.html', ques = quest)

@app.route('/pinglun/<question_id>')
def detial(question_id):
    quest=Question.query.filter(Question.id==question_id).first()
    return render_template('commentdetail.html',que=quest)

首页标题的标签做带参数的链接。
      {{ url_for('detail',question_id = foo.id) }}

<a href="{{ url_for('commentdetail',question_id=foo.id) }}">{{ foo.title}}</a>

 

在详情页将数据的显示在恰当的位置。 

{{ ques.title}}
{{ ques.id  }}{{  ques.creat_time }}

{{ ques.author.username }} 
{{ ques.detail }}

 

 {% for foo in question %}
    <li class="list-group-item">
        <span class="glyphicon glyphicon-leaf" aria-hidden="true"></span>
        <a href="{{ url_for('commentdetail',question_id=foo.id) }}">{{ foo.title}}</a>
        <p style="...">{{ foo.detail}}</p>
        <span class="glyphicon glyphicon-leaf" aria-hidden="true"></span>
        <span class="badge">{{ foo.creat_time}}</span>

    </li>
 {% endfor %}

建立评论的对象关系映射:

 

 

class Comment(db.Model):
    __tablename__='comment'

 

 尝试实现发布评论。

class Question(db.Model):
    __tablename__ = 'comment'
    id =db.Column(db.Integer,primary_key=True,autoincrement=True)
    author_id=db.Column(db.Integer,db.ForeignKey('uesr.id'))
    question_id=db.Column(db.Integer,db.ForeignKey('question.id'))
    creat_time=db.Column(db.DateTime,default=datetime.now)
    detail=db.Column(db.Text,nullable=False)
    question =db.relationship('Question',backref=db.backref('comments'))
    author=db.relationship('User',backref=db.backref('comments'))

 

posted on 2017-12-05 11:43  152陈斯璐  阅读(102)  评论(0编辑  收藏  举报