我想使用flask-assets 来组织我的网络 Assets 和mako 进行模板化。 Flask-assets 通常按以下方式使用 jinja:
{% assets "js_all" %}
<script type="text/javascript" src="{{ ASSET_URL }}"></script>
{% endassets %}
Mako 的等价物(据我所知)如下:
% assets 'coffee':
<script type="text/javascript" src="{{ ASSET_URL }}"></script>
% endassets
但是这会导致编译错误:
mako.exceptions.CompileException
CompileException: Unsupported control keyword: 'assets' in file '/index.html' at line: 8 char: 1
有没有办法在 Mako 中使用自定义控制关键字(例如“ Assets ”)?
这是我的 app.py 以供记录:
import os
from flask import Flask, render_template
from flask.ext import assets
from flask import config
from flask.ext.mako import MakoTemplates
from flask.ext.mako import render_template
app = Flask(__name__)
app.config['ASSETS_DEBUG'] = True
mako = MakoTemplates(app)
env = assets.Environment(app)
# Tell flask-assets where to look for our coffeescript and sass files.
env.load_path = [
os.path.join(os.path.dirname(__file__), 'js'),
os.path.join(os.path.dirname(__file__), 'styles'),
]
coffee = assets.Bundle('**/*.coffee', filters='coffeescript', output="app.js")
env.register('coffee', coffee)
@app.route("/")
def index():
return render_template('index.html', name='mako')
if __name__ == "__main__":
app.run(debug=True)
最佳答案
好吧,我想出了一个解决方案。您可以通过将环境导入到基本模板中并对其进行操作来使其工作。
Assets .py:
import os
from flask.ext import assets
from app import app
env = assets.Environment(app)
# Tell flask-assets where to look for our coffeescript and sass files.
env.load_path = [
os.path.join(os.path.dirname(__file__), 'js'),
os.path.join(os.path.dirname(__file__), 'styles'),
]
coffee = assets.Bundle('**/*.coffee', filters='coffeescript', output="app.js")
env.register('coffee', coffee)
模板:
<%!
from assets import env
%>
<!doctype html>
<html>
<head>
<title>Hello Flask</title>
<head>
<body>
<h1>Hello Flask</h1>
% for url in env['coffee'].urls():
<script src="${url}"></script>
% endfor
</body>
</html>
可能有办法通过使用 MAKO_IMPORTS 配置参数来避免导入,但我还没有使用它。
关于python - 将 Flask-Assets 与 Flask-Mako 结合使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27431664/