版本
flask版本:1.1.4
jinjia2版本:2.11.3
flask-script版本:2.0.6
flask-blueprint版本:1.3.0
flask-bootstrap版本:3.3.7.1
文档
flask英文文档:https://flask.palletsprojects.com/en/1.1.x/ flask中文文档:https://dormousehole.readthedocs.io/en/1.1.2/ jinja2英文文档:https://jinja.palletsprojects.com/en/3.0.x/ flask-bootstrap中文文档:https://flask-bootstrap-zh.readthedocs.io/zh/latest/ bootstrap3组件文档:https://v3.bootcss.com/components/
flask-script
a) 安装flask-script
pip install flask-script
data:image/s3,"s3://crabby-images/e4091/e40913465bc93c79c905ac4a4e9081ced7f4de6b" alt="在这里插入图片描述"
b) 修改app.py
from flask import Flask
from flask_script import Manager
app = Flask(__name__)
manager = Manager(app=app)
@app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
manager.run()
data:image/s3,"s3://crabby-images/7c8dc/7c8dc7a61cf86671d451c07849869794b6a61342" alt="在这里插入图片描述"
c) 运行
python app.py runserver -r -d
data:image/s3,"s3://crabby-images/44c9d/44c9d6954f512b4487883b40c0b2d3a7f852bd46" alt="在这里插入图片描述"
d) 浏览器访问
data:image/s3,"s3://crabby-images/d3dc5/d3dc5c2066487a9693f0418854fc43b51d5fcfdd" alt="在这里插入图片描述"
蓝图 flask-blueprint
a) 安装flask-blueprint
pip install flask-blueprint
b) 创建route.py
from flask import Blueprint
blue = Blueprint('blue', __name__)
@blue.route('/')
def hello_world():
return 'Hello World!'
@blue.route('/index/')
def index():
return 'Hello Index!'
data:image/s3,"s3://crabby-images/0f167/0f167f26f4aa8f67974d8b36b198d9e636645e0d" alt="在这里插入图片描述"
c) 修改app.py
from flask import Flask
from flask_script import Manager
from route import blue
app = Flask(__name__)
app.register_blueprint(blueprint=blue)
manager = Manager(app=app)
if __name__ == '__main__':
manager.run()
d) 访问
data:image/s3,"s3://crabby-images/c1ce4/c1ce4749f7c70906ea80373255d188b17ee11d09" alt="在这里插入图片描述"
render_template
a1) 创建home.html
data:image/s3,"s3://crabby-images/d5a41/d5a4198d990376b9f7756b697c203f0e2d89fb05" alt="在这里插入图片描述"
a2) 修改route.py
data:image/s3,"s3://crabby-images/9aedc/9aedc1540499e146ec55256ea260559ef76de69a" alt="在这里插入图片描述"
a3) 访问
data:image/s3,"s3://crabby-images/86920/86920aef50a0e508dac952f5901c126bf78e5608" alt="在这里插入图片描述"
b1) 修改route.py,传递数据,如字符串等
data:image/s3,"s3://crabby-images/f7e3c/f7e3ce4158f104e4c9344cc99bbfe810c3e45bdd" alt="在这里插入图片描述"
b2) home.html 中接收数据
data:image/s3,"s3://crabby-images/944a6/944a651d7fb5df103d0d95a08f350b48c643a08b" alt="在这里插入图片描述"
b3) 访问
data:image/s3,"s3://crabby-images/24f42/24f42480a6276e5ae405f4cf799e4ae2b573e462" alt="在这里插入图片描述"
url_for、redirect
a) 修改route.py
data:image/s3,"s3://crabby-images/54916/54916e8dea2b8a46b08236719e25d9a530731d61" alt="在这里插入图片描述"
b) 访问
http://127.0.0.1:5000
跳转至:
http://127.0.0.1:5000/home/
data:image/s3,"s3://crabby-images/08d67/08d67d6f53c795f7d218308cb20066bb8f22e93a" alt="在这里插入图片描述"
<a>标签跳转
从home跳转到 hello_world data:image/s3,"s3://crabby-images/0890f/0890fc0a4dacaf929bd90ea6c67518750a61248d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0241b/0241b5f19f2795746ab070d4325c7d7b321206b8" alt="在这里插入图片描述"
request
a) 添加/获取/删除Cookie
from flask import Blueprint
from flask import render_template
from flask import Response, request, redirect, url_for
blue = Blueprint('blue', __name__)
@blue.route('/')
def hello_world():
return 'index'
@blue.route('/setCookie/')
def setCookie():
rsp = Response('set cookie, 21')
rsp.set_cookie('myCookie', '21')
return rsp
@blue.route('/getCookie/')
def getCookie():
myCookie = request.cookies.get('myCookie')
return 'cookie is {}'.format(myCookie)
@blue.route('/deleteCookie/')
def deleteCookie():
rsp = redirect(url_for('blue.hello_world'))
rsp.delete_cookie('myCookie')
return rsp
b) 添加/获取/删除Session
app.py data:image/s3,"s3://crabby-images/e0c02/e0c021f288e08f108fdfa30843934657e343fd7a" alt="在这里插入图片描述" route.py data:image/s3,"s3://crabby-images/0b7c1/0b7c181083ccf5c0b1ef877687634033fb423abc" alt="在这里插入图片描述"
c) method (GET POST…) \ form表单提交
login.html data:image/s3,"s3://crabby-images/2990f/2990f4eebd5fba31f95ace2bd44a0744c9df2465" alt="在这里插入图片描述" route.py data:image/s3,"s3://crabby-images/3d376/3d376efc6c743af94f9e33727ecb8eaed6f20c66" alt="在这里插入图片描述"
jinja2模板
{% %} 控制语句,如
{% if data == 'name' %}
{{ data }}
{% else %}
{{ data }}
{% endif %}
{{ }} 变量,如 {{ data }}
{
a) 传递字符串
data:image/s3,"s3://crabby-images/5712d/5712d17b681235f3c6e7ba78ac21c533925f84ae" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/920a5/920a5e466e88680a5e33bb760dc0aa647abe1f1f" alt="在这里插入图片描述"
b) 传递列表 - for 循环
data:image/s3,"s3://crabby-images/e7863/e78630077d2942f9b2e98465452cf8c57e95fafc" alt="在这里插入图片描述"
for 遍历
data:image/s3,"s3://crabby-images/12144/12144322d1f9733e7ae1b4408c0e564487744fb4" alt="在这里插入图片描述"
根据索引取值
data:image/s3,"s3://crabby-images/5aada/5aada257f2f956063e38e3c9bcd4be943baacfb0" alt="在这里插入图片描述"
c) if 判断
data:image/s3,"s3://crabby-images/3c119/3c119e089b49e1247854fe8b659feb6a547b5c5b" alt="在这里插入图片描述"
d) set 设置变量
data:image/s3,"s3://crabby-images/ecd89/ecd8937474732bf5062f4a600151ad2443eefdbb" alt="在这里插入图片描述"
e) extends html引入html
base.html data:image/s3,"s3://crabby-images/89d66/89d66f4780369f2d1cbfcfe973cce378052eb517" alt="在这里插入图片描述" home.html data:image/s3,"s3://crabby-images/87a37/87a374bbd44291cd823ec5735b7c454343a50d99" alt="在这里插入图片描述"
f) 宏 macro
定义一个宏 macro data:image/s3,"s3://crabby-images/4fc66/4fc66cb78adc7e43b3b19edd15bae4771fb4b9e1" alt="在这里插入图片描述" 引入宏 data:image/s3,"s3://crabby-images/d7b69/d7b69aab2bc1e68844509d6cbcf7a80d750e0923" alt="在这里插入图片描述"
bootstrap
a) 安装flask-bootstrap
pip install flask-bootstrap
b) 引入
data:image/s3,"s3://crabby-images/27f02/27f0249647434d1def74722fa11580572106723f" alt="在这里插入图片描述"
c) 使用bootstrap
data:image/s3,"s3://crabby-images/23445/23445b09a84e99c3c65400f05ba1949cf935c6cc" alt="在这里插入图片描述"
自定义css
创建home.css
data:image/s3,"s3://crabby-images/bd99f/bd99f13409b887102a221deede1a8fd00ef40059" alt="在这里插入图片描述"
home.html引用css
{% extends "bootstrap/base.html" %}
{% block styles %}
{{ super() }}
<link rel="stylesheet" href="{{ url_for('static', filename='home.css') }}">
{% endblock %}
{% block content %}
<h2>hello</h2>
<h3>flask</h3>
{% endblock %}
data:image/s3,"s3://crabby-images/cc19e/cc19ec9637083983be7a0ccbaf17965dbd7d4fd3" alt="在这里插入图片描述"
自定义JS
创建js
$("#test_id").click(function(){
alert('test!test!')
});
data:image/s3,"s3://crabby-images/2a888/2a888274349031acb46b5304efb3ef060fdb0a13" alt="在这里插入图片描述"
引入js
{% extends "bootstrap/base.html" %}
{% block scripts %}
{{super()}}
<script src="{{url_for('static', filename='home.js')}}"></script>
{% endblock %}
{% block content %}
<button id="test_id">click</button>
{% endblock %}
data:image/s3,"s3://crabby-images/82a2b/82a2b0fbb9038ca4ac35ad5d8bf09912891327fb" alt="在这里插入图片描述"
|