flask蓝图

蓝图的使用

  • 1.目录结构:
flask蓝图_第1张图片
目录

app1: 单个应用的目录
app1/admin: app1下的一个功能模块
app1/admin/templates: 存放实现admin功能的模板文件
app1/admin/urls.py: 类似Django的urls,设置路由(此处创建admin专属的路由)
app1/admin/views.py: 模板渲染文件,类似Django的views
templates/index.html: 项目入口(或链接各个应用)的模板文件
apps.py: 创建Flask-app对象;注册蓝图,为蓝图添加前缀;启动应用

  • 2.文件内容

1.app1/admin/templates/index.html








    

    Admin





    

Admin

2.app1/admin/views.py

  • 渲染模板文件

from flask import render_template

def show_admin():

    return render_template('index.html')

3.app1/admin/urls.py

  • 注册蓝图admin,指明模板文件,添加蓝图路由

from flask import Blueprint

from .views import *

admin = Blueprint('admin', __name__, template_folder='admin_templates')

admin.add_url_rule('/show_admin/', view_func=show_admin)

4.apps.py

  • 创建Flask-app对象;注册蓝图,为蓝图添加前缀;启动应用

from flask import Flask

app1 = Flask(__name__)

from app1.admin.urls import admin

app1.register_blueprint(admin, url_prefix='/admin')

if __name__ == '__main__':

    app1.run(debug=True)

文件访问

  • 通过蓝图注册的静态文件及模板文件的访问规则如下:

1.如果在项目目录下存在静态文件和模板文件,则优先访问

flask蓝图_第2张图片
首页
  • manage_test/templates/index.html







    

    首页





    

首页

  • app1/admin/templates/index.html







    

    Admin





    

Admin

  • app1/admin/urls.py 创建蓝图对象admin,在manage_test/app.py中注册

from flask import Blueprint

from .views import *

admin = Blueprint('admin', __name__,

                static_folder='static',

                template_folder='templates')

admin.add_url_rule('/show_index/',

                  view_func=show_admin)

  • app1/admin/views.py 渲染网页

from flask import render_template

def show_admin():

    return render_template('index.html')

  • manage_test/apps.py 创建app对象及注册蓝图

from flask import Flask

app1 = Flask(__name__)

from app1.admin.urls import admin

app1.register_blueprint(admin, url_prefix='/admin')

if __name__ == '__main__':

    app1.run(debug=True)

  • 运行apps.py,打开浏览器显示结果如下
flask蓝图_第3张图片

2.如果项目目录下不存在静态文件和模板文件,则优先访问最先注册的蓝图目录下的文件

  • 1.删除manage_test/templates/index.html

    • 此时刷新网页显示结果如下:
flask蓝图_第4张图片
  • 2.创建grade文件夹,里面也创建一个templates文件夹及index.html文件

    • app1/grade/views.py
    
    from flask import  render_template
    
    def show_index():
    
        return render_template('index.html')
    
    
    • urls.py
    
    from flask import Blueprint
    
    from .views import *
    
    grade = Blueprint('grade', __name__,
    
                    static_folder='static',
    
                    template_folder='templates')
    
    grade.add_url_rule('/show_index/',
    
                      view_func=show_index)
    
    
    • manage_test/apps.py 新增一个蓝图grade的注册
    
    from flask import Flask
    
    app1 = Flask(__name__)
    
    from app1.admin.urls import admin
    
    from app1.grade.urls import grade
    
    app1.register_blueprint(grade, url_prefix='/grade')
    
    app1.register_blueprint(admin, url_prefix='/admin')
    
    if __name__ == '__main__':
    
        app1.run(debug=True)
    
    
    • 此时刷新网页:

admin/show_index


flask蓝图_第5张图片

grade/show_index


flask蓝图_第6张图片

Tip:

  • 使用flask蓝图设置路由时需要注意静态文件和模板文件不能同名

推荐做法一: 在每个功能模块下的静态和模板文件夹下再创建一个与应用同名的文件夹

  • 修改admin/views.py return render_template('admin/index.html')

此时admin/show_index显示:


flask蓝图_第7张图片

推荐做法二: 每个模块在创建文件夹时加上模块名 admin_templates

(当然如果是小组开发,也可以使用代号LZ_templates)

推荐做法三: 根据模板文件的功能命名,确保不会与其他模块重名

issue

  • ValueError: urls must start with a leading slash

蓝图在注册添加前缀时没有加'/'

你可能感兴趣的:(flask蓝图)