三11、从首页问答标题到问答详情页

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

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

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

 

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

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

 

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

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

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

{% for foo in questions %}
    <ul class="new-list">
    <li>
            <a href="#">{{ foo.author.username }}</a><br>
            <a target="_self" href="{{ url_for('detail',question_id=foo.id) }}">{{ foo.title }}</a>
            <p>
            {{ foo.detail }}
            </p>
        <span class="post_item_foot">
            发布于   {{ foo.create_time }}
        </span>
             </li>
       </ul>

 

4.创建评论的对象关系映射:code

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

class Comment(db.Model):
    __tablename__ = 'comment'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    question_id = db.Column(db.Integer, db.ForeignKey('question.id'))
    create_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'))

5.尝试实现发布评论。对象

相关文章
相关标签/搜索