程序员Flask

Flask 配置静态资源文件夹static_url_path、s

2018-07-09  本文已影响389人  非梦nj

如何动态配置静态文件夹 static

image

问题

默认的Flask项目文件结构是这样的:

/app.py
/static
    /js
    /css
    /img
/templates
    /index.html

然后,你的前端访问后台静态资源,是通过这个/static/file.nameurl:

<link as=style href=/static/css/app.697eaad8.css rel=preload>
<img src="/static/img/mylogo.jpg" />

问题来了,在有些前端应用中,资源文件必须要使用根路径/
比如PWA的manifest文件:

<link rel=manifest href=/manifest.json>

如何让Flask访问到这些根路径的文件呢?

解决

文档:http://flask.pocoo.org/docs/1.0/api/#configuration
class flask.Flask(import_name, static_url_path=None, static_folder='static', static_host=None, host_matching=False, subdomain_matching=False, template_folder='templates', instance_path=None, instance_relative_config=False, root_path=None)

配置一下static_url_pathstatic_folder就可以了。

一个粟子:

from flask import Flask, render_template

app = Flask(__name__, static_url_path='')

@app.route('/')
def index():
    return render_template('index.html')

源码:https://github.com/kevinqqnj/flask-vue-pwa
PWA演示:https://flask-vue-pwa.herokuapp.com/

上一篇 下一篇

猜你喜欢

热点阅读