制作首页的显示列表 + 发布功能完成
1. 在首页添加显示问答的列表,并定义好相应的样式。
无序列表
<ul >
<li>Coffee</li>
<li>Tea</li>
<li>Milk</li>
</ul>
{% extends "base.html" %} {% block title %}首页{% endblock %} {% block head %}{% endblock %} {% block main %} <img scr="{{ url_for('static',filename='images/logo.png') }}" alt="qa"> <p>{{ username}}context</p> <ul class="list-group" style="..."> <li class="list-group-item"> <span class="glyphicon glyphicon-leaf" aria-hidden="true"></span> <a href="#">{{ user }}</a> <br> <a href="#">标题</a> <span class="badge">发布时间</span> <p style="...">内容</p> </li> </ul> {% endblock %}
2. 用字典向index.html传递参数。
@app.route('/') def index(): context={ 'user':'mis' } return render_template("index.html")
- 编写要求登录的装饰器
from functools import wraps
def loginFirst(func): #参数是函数
@wraps(func)
def wrapper(*args, ** kwargs): #定义个函数将其返回
#要求登录
return func(*args, ** kwargs)
return wrapper #返回一个函数
def loginFirst(func): #行动前需要登录,定义装饰器 @wraps(func) def wrapper(*args,**kwargs): if session.get('user'): return func(*args,**kwargs) else: return redirect(url_for('login')) return wrapper
- 应用装饰器,要求在发布前进行登录,登录后可发布。
@app.route('/question/',methods=['GET','POST'])
@loginFirst
def question():
@app.route('/question/',methods=['GET','POST'])
@loginFirst
def question():
- 建立发布内容的对象关系映射。
class Question(db.Model):
class Question(db.Model): __tablename__ = 'question' id =db.Column(db.Integer,primary_key=True,autoincrement=True) title=db.Column(db.String(100),nullable=False) detail=db.Column(db.Text,nullable=False) creat_time=db.Column(db.DateTime,default=datetime.now) author_id=db.Column(db.Integer,db.ForeignKey('user.id')) #外键约束 author=db.relationship('User',backref=db.backref('question'))
- 完成发布函数。
保存到数据库。
重定向到首页。
@app.route('/question/',methods=['GET','POST']) @loginFirst def question(): if request.method=='GET': return render_template('question.html') else: title=request.form.get('title') detail=request.form.get('detail') author_id=User.query.filter(User.username==session.get('user')).first().id question=Question(title=title,detail=detail,author_id=author_id) db.session.add(question) # 数据库,添加操作 db.session.commit() return redirect(url_for('index'))