Flask自己写日记蓝图


8月份,我正式开始学习。第一遍看的时候,压根看不懂。只能通过checkout它版本库里的每个版本来联系书中内容进行学习。这样我就花了一个月时间简单过了一遍。

9月份,我虽然过了一遍,可是感觉书中知识没有变成我自己的。我还没有真正学会。我不知道该怎么做,就把书中的内容手打了一遍。做了一个微博出来,并且部署上线了


QQ截图20161008233441.png

即使这样我还是有一种不安的感觉在心中。我觉得,我还是没有真正学会flask这个框架。期间为了缓解疲劳,我有一个礼拜放下了flask的学习,跑去学写爬虫去了。还写了些卵东西...


IMG_2823.PNG

在我去泰国度假以前,我本来设定的下一步学习方案是学会如何使用模板,把我的网站弄漂亮。还有利用爬虫把爬回来的东西放到网站上去。
现在回来以后,怎么说呢。我有种感觉,始终得先回归书中知识,把一些章节搞清楚心里才踏实,然后才去做刚才我写的那些。

<strong>10.9号更新</strong>
今天9点我就起来了比平时起早了一个小时。睡醒以后马上就知道自己要学什么做什么了。所以人啊,千万不要熬夜。一觉睡醒,思路就通了。今天先定个小目标:自己做个博客的页面,然后利用flask的蓝图加入到我原来的微博中。好了,首先第一件事就是要做个博客的页面。我查了查bootstrap的各种用法,找到了个可是编辑器以后,一切都变得简单起来了。

火狐截图_2016-10-09T09-50-28.820Z.png

这是我的博客页面,带有缩略图,标题,摘要。点击detail可以打开博文页面
上一下代码让大家看看思路

<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <div class="row">
                {% for post in posts %}
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img alt="300x200" src={{ post.src }} />
                        <div class="caption">
                            <h3>
                                {{ post.title }}
                            </h3>
                            <p>
                                {{ post.body [:20]}}
                            <p>
                                 <a class="btn btn-info" href="{{ url_for('.post', id=post.id) }}">Detail</a> 
                            </p>
                        </div>
                    </div>
                </div>
                {%endfor%}
            </div>
        </div>
    </div>
</div>
火狐截图_2016-10-09T09-52-03.340Z.png

基本的功能都实现了,by the way 下面的输入框肯定要加入权限的,只有管理员可见。然后剩下的就是蓝图了。今天很幸运,没遇到什么坑,没怎么卡住。明天再弄蓝图把。

<strong>10.10</strong>
我的灵魂遭受了会心一击。。。我今天好努力的把蓝图写好插入结果它给我提示这个吊玩意


QQ截图20161010172816.png

特么的数据库又怎么了!!!我把新写的蓝图删了还是不行!我把版本切回到之前还是不行!!最后我把所有代码怒删了!!
现在是晚上8点50分,我刚健身回来,感觉心力交瘁。直到现在,我还是没办法重新开始写代码。
好了,写了一个多小时代码,运行报错!

![I}D~I9BWEZ}0V)318%$]MP6.png](http://upload-images.jianshu.io/upload_images/2577034-22f936dfb52d07e3.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

QQ图片20161010222242.png

找到问题了

{% extends "base.html" %}
{% import "bootstrap/wtf.html" as wtf %}
{% import "_macros.html" as macros %}
{% block title %}Leon blog{% endblock %}
{% block content %}
<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <div class="row">
                {% for diary in diarys %}
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img alt="300x200" src={{ diary.src }} />
                        <div class="caption">
                            <h3>
                                {{ diary.title }}
                            </h3>
                            <p>
                                {{ diary.body [:20]}}
                            <p>
                                 <a class="btn btn-info" href=#>Detail</a>
                            </p>
                        </div>
                    </div>
                </div>
                {%endfor%}
            </div>
        </div>
    </div>
</div>




<div class="pagination">
    {{ macros.pagination_widget(pagination, '.index') }}
</div>
<div class="pagination">
    {{ macros.pagination_widget(pagination, '.index') }}
</div>

是这部分的错!

火狐截图_2016-10-10T14-48-14.232Z.png

我以为我成功了,可我还是太天真了。。。


提交新博客的时候它返回错误。。。。

<strong>10.11</strong>
一大早醒来,我思考了下。

from flask import request,render_template, redirect,url_for
from . import diary
from .. import db
from ..models import Diary
from .forms import DiaryForm
from config import config

@diary.route('/diary', methods=['GET', 'POST'])
def blog():
    form = DiaryForm()
    if form.validate_on_submit():

        diary = Diary(title=form.title.data,body=form.body.data,src=form.src.data)
        db.session.add(diary)
        return redirect(url_for('diary'))
    page = request.args.get('page',1, type=int)
    pagination = Diary.query.order_by(Diary.timestamp.desc()).paginate(
        page,per_page=20,
        error_out=False)
    diarys = pagination.items
    return render_template('diary.html', form = form,diarys=diarys,pagination=pagination)

我把

return redirect(url_for('diary'))

删掉了
然后再提交

火狐截图_2016-10-11T03-26-15.585Z.png

没有报错了!!!
。。。可是,它不会自己刷新

我需要再改一下代码,我把views的

return redirect(url_for('diary'))
放回去,并且改成return redirect('diary')
然后就成功了!!这次真的成功了!!
好了上代码把

QQ截图20161012001852.png

这是我的蓝图结构

diary的init.py

from flask import Blueprint

diary = Blueprint('diary', name)

from . import views
` ```

diary的forms.py

from flask_wtf import Form
from wtforms import StringField, SubmitField,TextAreaField
from wtforms import ValidationError
from wtforms.validators import Required

class DiaryForm(Form):
    title = StringField('title')
    body = TextAreaField("What's on your mind?", validators=[Required()])
    src = StringField("pics link?", validators=[Required()])
    submit = SubmitField('Submit')

diary的views.py

from flask import request,render_template, redirect,url_for
from . import diary
from .. import db
from ..models import Diary
from .forms import DiaryForm
from config import config

@diary.route('/diary', methods=['GET', 'POST'])
def blog():
    form = DiaryForm()
    if form.validate_on_submit():

        diary = Diary(title=form.title.data,body=form.body.data,src=form.src.data)
        db.session.add(diary)
        return redirect('diary')
    page = request.args.get('page',1, type=int)
    pagination = Diary.query.order_by(Diary.timestamp.desc()).paginate(
        page,per_page=20,
        error_out=False)
    diarys = pagination.items
    return render_template('diary.html', form = form,diarys=diarys,pagination=pagination)

diary.html

{% extends "base.html" %}
{% import "bootstrap/wtf.html" as wtf %}
{% import "_macros.html" as macros %}
{% block title %}Leon blog{% endblock %}
{% block content %}
<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <div class="row">
                {% for diary in diarys %}
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img alt="300x200" src={{ diary.src }} />
                        <div class="caption">
                            <h3>
                                {{ diary.title }}
                            </h3>
                            <p>
                                {{ diary.body [:20]}}
                            <p>
                                 <a class="btn btn-info" href=#>Detail</a>
                            </p>
                        </div>
                    </div>
                </div>
                {%endfor%}
            </div>
        </div>
    </div>
</div>



{% if current_user.can(Permission.MODERATE_COMMENTS) %}#这里我偷懒,直接把语句复制过来的。可以修改评论的权限等同于管理员权限了
    {{ wtf.quick_form(form) }}
{%endif%}
{% endblock %}

暂时就这样先吧,明天再做修改

<strong>10.12</strong>
今天做最后的diary单独网页,上代码
views

@diary.route('/diary/<int:id>', methods=['GET', 'POST'])
def diary(id):
    diary = Diary.query.get_or_404(id)
    return render_template('diarys.html', diarys=[diary])
                           

新建一个diarys.html

{% extends "base.html" %}


{% block title %}Flasky - Diary{% endblock %}
{% block content %}
{% for diary in diarys %}
<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <h3>
                {{ diary.title }}.
            </h3>
            <p>
                 {{ diary.body }}
                
            </p><img alt="140x140" src={{ diary.src }} />
             {<p>{{ moment(diary.timestamp).fromNow() }}</p>
            
        </div>
    </div>
</div>
{%endfor%}
{% endblock %}

点击detail

火狐截图_2016-10-12T07-57-18.969Z.png

成功了 呀!!!!

火狐截图_2016-10-12T07-55-48.770Z.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容

  • 22年12月更新:个人网站关停,如果仍旧对旧教程有兴趣参考 Github 的markdown内容[https://...
    tangyefei阅读 35,156评论 22 257
  • 什么是蓝图? 一个蓝图定义了视图,模板,静态文件以及可以用于应用程序的其它元素的集合。例如,让我们假设下我们有一个...
    邪恶的Sheldon阅读 1,132评论 0 1
  • 本文首发于Gevin的博客 原文链接:Flask 入门指南 未经 Gevin 授权,禁止转载 1. 初识Flask...
    Gevin阅读 16,706评论 10 237
  • 第七章 大型程序架构 虽然在一个脚本里完成一个web应用很便利,但是这也意味着它很难扩展。当程序不断增长,越来越复...
    易木成华阅读 901评论 0 1
  • 作者:杜志鹏链接:https://www.zhihu.com/question/31748237/answer/5...
    cexpert阅读 3,660评论 1 5