2

Flask-assets を使用して webassets を整理し、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 でカスタム コントロール キーワード (「アセット」など) を使用する方法はありますか?

これが記録用の私の 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)
4

2 に答える 2

2

さて、私は解決策を思いつきました。環境を基本テンプレートにインポートし、それに基づいて操作することで機能させることができます。

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 構成パラメーターを使用してインポートを回避する方法があるかもしれませんが、私はそれを試していません。

于 2014-12-11T21:27:06.273 に答える
1

Flask-Assetsは、webassets の Jinja 拡張機能を Flask の Jinja 環境に登録するだけです。WebAssets は、(この記事の執筆時点では) Jinja2の拡張機能のみを同梱しているため、Mako のアセット タグが必要な場合は、自分で作成する必要があります(ただし、誰かがPyramidに似たようなものを既に書いているので、そこからインスピレーションを得てください)。

于 2014-12-11T20:59:24.853 に答える