其实关于什么用flask搭建一个后台博客啥的跟着官方文档做一遍就行了。感觉啥都有我这里就不赘述了只是记录一个笔记,因为稍微有几个地方有点坑。

目标:做了一个简易页面给电商的同事用来添加商品

首先是安装flask和mako。

这里注意不仅要安装mako还要安装mako针对flask的扩展才能正常使用。

Flask==0.10.1
flask-mako==0.3
flask-peewee==0.6.6
mako==1.0.3

使用pip install一个一个安装或者使用pip install -r 安装配置文件这个无所谓,这里只是列出需要安装的包

下面正式进入项目。

贴出应用内的__init__配置:

from flask import Flask
from flask.ext.mako import MakoTemplates app = Flask(__name__)
mako = MakoTemplates(app)
import kepler.app.views.jd_view.stock # noqa
import kepler.app.views.jd_view.balance # noqa
import kepler.app.views.jd_view.address # noqa
import kepler.app.views.jd_view.idmap # noqa
import kepler.app.views.jd_view.after_sale # noqa

讲解一下配置,首先是一个flask_app这个没啥好说的,下面那个mako是我使用mako对flask的扩展,使用这个扩展必须在app里初始化,否则就会失败。

__init__这个初始化文件里面还会有一些从views文件夹里面引入的文件,这是帮助其他views在引入了__init__文件里的app构造路由的时候,路由能正确的找到对应的函数。

这样配置完毕之后,在templates文件夹下面就可以正常使用模版文件了,在views文件夹下面的函数使用render_template函数也能正常找到对应的模版。

这里贴上app内的文件目录:

具体的mako使用方法我这里就不赘述了反正模版引擎的使用大多大同小异,参考官方文档:http://www.makotemplates.org

这里还要提一下关于flask的静态文件寻址的问题,当我们使用了模版引擎并且使用了flask框架之后,在templates里面的文件的寻址方式就不再是普通的方式。所有的路由规则都将由flask进行控制。当你试图在templates里面去引用static里面的某个css的时候,直接写文件路径的相对对路径是无法找到对应的文件的。这点大家尝试过的想必都非常清楚。稍微在flask文档里面寻找一下能了解到,flask针对静态文件寻址提供好了现成的方法。

下面引用官方文档的描述:http://flask.pocoo.org/docs/0.10/quickstart/#about-responses

Static Files

Dynamic web applications also need static files. That’s usually where the CSS and JavaScript files are coming from. Ideally your web server is configured to serve them for you, but during development Flask can do that as well. Just create a folder called staticin your package or next to your module and it will be available at /static on the application.

To generate URLs for static files, use the special 'static' endpoint name:

url_for('static', filename='style.css')

The file has to be stored on the filesystem as static/style.css.

所以当你的一个html模版需要使用到css,js,img之类资源的使用,进行静态文件寻址只需要

<link href="${url_for('static', filename='css/bootstrap.min.css')}" rel="stylesheet">

这里的寻址路径就是static文件夹下面,css/bootstrap.min.css文件,其他的使用静态文件的方式与之大同小异。

我将在下一篇介绍单独介绍一下peewee的使用。个人觉得peewee可以说是flask orm中的佼佼者,还是比较好用,也推荐使用。

  

  

flask+mako+peewee(上)的更多相关文章

  1. flask+mako+peewee(下)(解决了Error 2006: MySQL server has gone away)

    这篇主要介绍在这次项目中使用的peewee 文档地址:http://peewee.readthedocs.org/en/latest/index.html 首先我们要初始化一个数据库连接对象.这里我使 ...

  2. flask在windows上用mod_wsgi部署

    flask在windows上用mod_wsgi部署也是折腾了不少时间,下面就总结下. 首先下载Apache httpd,我认为Apache Hans比较好: 一般这种情况下,你的python环境已经安 ...

  3. Flask入门文件上传flask-uploads(八)

    1 视图传递多个参数 (1) 普通传参 : 关键字参数传递 return render_template('模板名称.html',arg1=val1,arg2=val2...) (2) 字典传参 : ...

  4. Flask—04-文件上传与邮件发送(自带优化)

    文件上传与邮件发送 可以按照标题分别直接粘贴对应的文件夹,运行直接用: 原生上传 模板文件 <form method="post" enctype="multipa ...

  5. flask文件的上传和下载

    from werkzeug.utils import secure_filename from flask import Flask,render_template,jsonify,request i ...

  6. Flask -- 请求、上传文件、Cookies

    请求对象 from flask import request request.method #值为form表单提交的method 'POST'. 'GET'等 #如果值为'POST'或'PUT',则可 ...

  7. flask jQuery ajax 上传文件

    1.html 代码 <div> <form id="uploadForm" enctype="multipart/form-data" > ...

  8. flask完成文件上传功能

    在使用flask定义路由完成文件上传时,定义upload视图函数 from flask import Flask, render_template from werkzeug.utils import ...

  9. 在 Django/Flask 开发服务器上使用 HTTPS

    使用 Django 或 Flask 这种框架开发 web app 的时候一般都会用内建服务器开发和调试程序,等程序完成后再移交到生产环境部署.问题是这些内建服务器通常都不支持 HTTPS,我们想在开发 ...

随机推荐

  1. ubuntu16.04node和npm卸载干净

    如下命令便可以实现该目的: #apt-get 卸载 sudo apt-get remove --purge npm sudo apt-get remove --purge nodejs sudo ap ...

  2. django_redis作为 session backend 使用配置

    Django 默认可以使用任何 cache backend 作为 session backend, 将 django-redis 作为 session 储存后端不用安装任何额外的 backend # ...

  3. C# 语法三 抽象类和接口

    1.抽象类 2.接口 一 抽象类 跟普通类的区别: a)用abstract标识类.抽象方法 b)抽象方法,只能声明,不能定义 c)抽象类不能实例化 二 接口 接口用interface标识,所有的成员( ...

  4. TerraGate软件安装后,不能启动的解决办法

    在服务端安装Skyline的TerraGate软件的时候,大家可能会遇到过这样的问题,“TerraGate软件安装后,不能启动”,很多时候,这个问题是因为TerraGate设 置的端口号已经被占用造成 ...

  5. 办公室的远程传文件 的命令三种方式linux

    不同的Linux之间copy文件常用有3种方法: 第一种就是ftp,也就是其中一台Linux安装ftp Server,这样可以另外一台使用ftp的client程序来进行文件的copy. 第二种方法就是 ...

  6. WebService与CXF

    一:Webservice 1:WebService是干什么的?有什么用? 一言以蔽之:WebService是一种跨编程语言和跨操作系统平台的远程调用技术. 所谓跨编程语言和跨操作平台,就是说服务端程序 ...

  7. BZOJ3720 Gty的妹子树 询问分块、主席树

    传送门 学到了询问分块的科技-- 对于修改操作,每发生了\(S\)次修改就重构整棵树,小于\(S\)次的修改操作丢到一个队列里面. 对于每一次查询操作,先在主席树上查询当前子树内部大于\(k\)的节点 ...

  8. 转:判断js中的数据类型的几种方法

    判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...

  9. zookeepeer4字命令实践

    环境 leader:192.168.116.143 fllower:192.168.116.142 fllower:192.168.116.144 命令:conf——查看其他主机的配置文件 [root ...

  10. 两个非常好的bootstrap模板,外送大话设计模式!

    两个非常好的bootstrap模板,外送大话设计模式! 下载地址:http://download.csdn.net/download/wolongbb/10198756