Flask Web 开发 博客文章

来源:互联网 发布:qt线程间通信 数组 编辑:程序博客网 时间:2024/06/06 08:56

进入新的一章节了

又是一个比较大的功能,写博客

class Post(db.Model):__tablename__ = 'posts'id = db.Column(db.Integer,primary_key = True)body = db.Column(db.Text)                      #文章内容timestamp = db.Column(db.DateTime,index = True, default = datetime.utcnow)  #时间戳,据现在多久author_id = db.Column(db.Integer,db.ForeignKey('users.id'))  #外键,和users表相连


既然Post类里有外键,那么,User类里面必定有相连接的属性,如下


class User(UserMixin, db.Model):# ...posts = db.relationship('Post', backref='author', lazy='dynamic')   #和Post类相连接的桥梁


写文章的地方,放在主页,设置一个表单,让客户可以输入内容

那就新建一个form

class PostForm(Form):body = TextAreaField("What's on your mind?", validators=[Required()])submit = SubmitField('Submit')

既然是要在主页上显示表单,那么,主页的内容势必要做修改了

@main.route('/', methods=['GET', 'POST'])def index():form = PostForm()if current_user.can(Permission.WRITE_ARTICLES) and \           #检查用户是否有写文章权限form.validate_on_submit():post = Post(body=form.body.data,                       #将文章内容生成post实例author=current_user._get_current_object())db.session.add(post)return redirect(url_for('.index'))posts = Post.query.order_by(Post.timestamp.desc()).all()       #posts代表所有写过的文章,按照文章降序排列return render_template('index.html', form=form, posts=posts)


这里的current_user._get_current_object()的用法,是提取真正的对象

其实current_user只是一个代理包装后的对象,而这里数据库需要的是真正的对象

不是理解特别深,不过这个方法指导如何使用了。


逻辑部分改完,就要改显示的模板部分了

{% extends "base.html" %}{% import "bootstrap/wtf.html" as wtf %}{% block title %}Flasky{% endblock %}{% block page_content %}{% block scripts %}                   <!-- 记得引入moment扩展 -->{{ super() }}                 {{ moment.include_moment() }}{% endblock %}...<div>{% if current_user.can(Permission.WRITE_ARTICLES) %}   {{ wtf.quick_form(form) }}{% endif %}</div><ul class = "posts">{% for post in posts %}                         <!-- 历遍所有的posts --><li class = "post"><div class="profile-thumbnail"><a href = "{{ url_for('.user',username = post.author.username) }}">  <!--图片做超链接,目标用户页面--><img class = "img-rounded profile-thumbnail"src = "{{ post.author.gravatar(size = 40) }}">           <!-- 图片来源于gravatar --></a></div><div class="post-date">{{ moment(post.timestamp).fromNow() }}</div><div class="post-author"><a href = "{{ url_for('.user',username = post.author.username) }}">   <!-- 点击名字也导向用户页面 -->{{ post.author.username }}</a></div><div class = "post-body">{{ post.body }}</div>         <!-- 文章内容 --></li>{% endfor %}</ul>{% endblock %}



效果图如下。






----------------------------------------------------------------------------功能分割线--------------------------------------------------------------------------------------


除了在主页看到所有人的留言之外,我们还需要在个人主页看到该用户自己所有的博客文章

那我们势必要在user.html页面内修改内容

其实,2个模板块里面调用的对象都是一样的,都是posts,所以我们可以统一化管理,将这部分调用功能单独做出来做成一个html文件

posts = Post.query.order_by(Post.timestamp.desc()).all()   #找Post类里面的所有内容
posts = user.posts.order_by(Post.timestamp.desc()).all()   #找当前用户的posts属性(对应Post类里面的所有博客)


所以,我们在user类里面通过下面的方法引入 _posts.html 内容,其实这个和extends功能感觉有异曲同工的味道

另外,同时在index.html里面用到这部分的,也要引用这个功能模板

<ul class = "posts">{% for post in posts %}<li class = "post"><div class="profile-thumbnail"><a href = "{{ url_for('.user',username = post.author.username) }}"><img class = "img-rounded profile-thumbnail"src = "{{ post.author.gravatar(size = 40) }}"></a></div><div class="post-date">{{ moment(post.timestamp).fromNow() }}</div><div class="post-author"><a href = "{{ url_for('.user',username = post.author.username) }}">{{ post.author.username }}</a></div><div class = "post-body">{{ post.body }}</div></li>{% endfor %}</ul>

在user.html里面

使用下面语句来引入

<h3>Posts by {{ user.username }}</h3>
{% include "_posts.html" %}

注意,_posts.html 模板名的下划线前缀不是必须使用的,这只是一种习惯用法,以区分独立模板和局部模板。


效果图如下










0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 红米4a上网太慢怎么办 华为光猫网线接囗接触不良怎么办? 苹果电信4g信号变3g怎么办 苹果7的4g变3g了怎么办 华为路由器的登录密码忘记了怎么办 华为手机有4g但不能上网怎么办 移动4g 手机开密码忘了怎么办 华为安卓8.0屏幕上圆怎么办 苹果5s不能用4g怎么办 电动车的锁住了钥匙丢了怎么办 小米蓝牙耳机青春版开不了机怎么办 小米蓝牙耳机进水了开不了机怎么办 新买的蓝牙耳机开不了机怎么办 蓝牙耳机长时间不用开不了机怎么办 瑞和宝pos机无法连接蓝牙怎么办 手机做话筒连蓝牙音箱不同步怎么办 荣耀畅玩7x触屏不灵怎么办 华为6x屏幕点没反应怎么办 苹果耳机按一下就挂断电话怎么办 华为畅享7忘记账号密码怎么办 华为荣耀8手机外放声音小怎么办 安卓手机耳机减音量不能用怎么办 苹果手机微信语音是耳机模式怎么办 平果手机没声音出现耳机模式怎么办 苹果6s进水了一直耳机模式怎么办 华为手机没声音显示耳机模式怎么办 华为手机没声音出现耳机模式怎么办 安卓手机全民k歌耳返延迟怎么办 华为手机双清后手机开不了机怎么办 荣耀9上面有个耳机标志怎么办 华为p9耳机有一个没有声音怎么办 小米5c手机gps信号弱怎么办 华为8手机时常听常音乐声怎么办 手机用久了变慢了怎么办 免税店买的皮带太短了怎么办 小米手机自拍照片是反的怎么办 华为p20旅行助手被删了怎么办 假如手机点击一个链接是病毒怎么办 华为手机自带铃声没了怎么办 华为手机升级后铃声没了怎么办 华为平板电脑激活锁忘记了怎么办