Flask-Admin
说明
flask
轻量型web服务框架,官方给的特点是:微,意味着仅有基础的服务功能。在开发中,基本上还要依赖一些有扩展功能的扩展包。
flask-admin
基于flask的扩展包,主要功能是支持默认的web管理界面,类似于django的admin。当然,在使用中,还涉及其他的扩展包。
文档说明
以github项目实例为引导,学习flask-admin的文档笔记
Hello World
在项目文件夹下创建 app.py/wsgi.py (项目目录下命令行执行flask run flask默认找这两个文件)
-
创建app
# app.py from flask import Flask import flask_admin as admin app = Flask(__name__, template_folder='templates') # 指定模板文件目录 所以要创建templates文件夹 app.debug = Trues # debug模式,服务开启时,程序发生修改,服务会自动重载。
-
设置第一个路由
# app.py ... @app.route('/') def index(): return '<a href="/admin/">Click me to get to Admin!</a>'
-
创建flask-admin视图
# app.py ... admin = admin.Admin(name="Example: Simple Views", template_mode='bootstrap4') # template_mode 模板样式 admin.init_app(app)
在app.py同级目录执行 flask run ,浏览器访问 http://127.0.0.1:5000/admin/
可以看出admin.Admin()的anme参数对应的就是视图的title。template_mode表示模板样式。 -
导航栏添加栏目
创建两个视图类,并在admin初始化前,将视图类绑定到admin对象中# app.py ... # 继承admin.BaseView 创建视图类 class MyAdminView(admin.BaseView): @admin.expose('/') def index(self): return self.render('myadmin.html') class AnotherAdminView(admin.BaseView): @admin.expose('/') def index(self): return self.render('anotheradmin.html') @admin.expose('/test/') def test(self): return self.render('test.html') admin = admin.Admin(name="Example: Simple Views", template_mode='bootstrap4') # 添加到admin admin.add_view(MyAdminView(name="view1", category='Test')) admin.add_view(AnotherAdminView(name="view2", category='Test2')) admin.init_app(app)
这里贴出html内容,可以看到:- 一个视图类表示一个路由分级
- 视图类类名即为该路由地址
- 视图类中以@admin.expose(’/’)装饰器装饰函数的方式实现下级地址,如:
class AnotherAdminView(admin.BaseView): @admin.expose('/') def index(self): return self.render('anotheradmin.html') @admin.expose('/test/') def test(self): return self.render('test.html')
访问路由 /AnotherAdminView/ 会得到anotheradmin.html页面,而 /AnotherAdminView/test/ 会得到test.html页面。
-
flask返回页面
先创建一个index.html用来展示
# app.py
...
from flask import render_template
...
# 创建第一个路由
@app.route("/")
def index():
return render_template('index.html')