Flaskr 开发说明
官方文档
http://flask.pocoo.org/docs/0.12/tutorial/
演示网站
http://flaskr.it592.com/
涉及到的内容:
- 连接sqlite,增删查
- 模板使用
- 应用上下文、请求上下文
- session
- 单元测试
- g,app.cli.command()
知识点详解
- 连接sqlite
rv = sqlite3.connect("sqlite所在的位置")
rv.row_factory = sqlite3.Row # 将查询数据和查询语句组合为字典的形式,而非tuple
- 模板的使用
render_template("index.html",name = "")
# 模板使用很简单
# 在模板中变量取值用 {{ name}}
# 判断
{% if flag %}
{% else %}
{% endif %}
# 循环
{% for x in name%}
{% endfor%}
# 模板继承
{% extends 目标名%}
# url生成
{{url_for("index")}}
{{url_for("static",filename="")}} #静态资源
- g对象的使用
# g 对象是和当前应用上下文有关的变量,能够保证线程安全,我们可以用来存储当前请求的一些信息
def get_db():
if not hasattr(g, "sqlite_db"):
g.sqlite_db = connect_db()
return g.sqlite_db
# 对于不同的请求,g对象的内容是不同的
- app.cli.command()
#app.cli.command() 会给flask脚本注册一个新的命令,并且自动创建应用上下文
@app.cli.command('initdb') #注册initdb命令,
def initdb_command():
"""Initializes the database."""
init_db()
print('Initialized the database.')
- 单元测试
根据flaskr.app.test_client()来发出get、post请求