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

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

@app.route('/detail/<question_id>')  # 和idea的update一样,将id带到控制器
def detail(question_id):
    fa = Question.query.filter(Question.id == question_id).first()  # 根据id查询出整条元组记录,丢进fa
    return render_template('detail.html', fa=fa)  # 把值fa丢进键fa,在fabuview.html页面调用

 

2、首页标题的标签做带参数的链接

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

           <ul class="list-unstyled">
                {% for foo in question %}
                <li class="list-group-item-success">
                    <a href="#">{{ foo.author.username }}</a>
                    <h4 class="text-center"><a href="{{ url_for('detail',question_id=foo.id) }}">{{ foo.title }}</a>
                    </h4>
                    <span class="badge pull-right">{{ foo.creat_time }}</span>
                    <br>
                    <p>{{ foo.detail }}</p>
                </li>
                {% endfor %}
            </ul>

4、建立评论的对象关系映射

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'))
    detail = db.Column(db.Text, nullable=False)
    crea_time = db.Column(db.DateTime, default=datetime.now)
    author = db.relationship('User', backref=db.backref('comment'))
    question = db.relationship('Question', backref=db.backref('comment'))

 

posted on 2017-12-05 09:50  张木清  阅读(203)  评论(0编辑  收藏  举报

导航