テンプレートエンジンとフォームプラグイン(Python)の詳しい使用例を教えます。

Y2J
リリース: 2017-04-26 10:12:36
オリジナル
1799 人が閲覧しました

最初の章の内容を終えたら、すでにいくつかの簡単なページを作成できます。まず、このメソッドを使用してログイン ページを作成します。ログイン ページの表示結果は次のとおりです:

次に、ログイン後の戻りページがあります:

@app.route("/login",methods=["GET"])
def login():
 html="<form method=&#39;post&#39;>" \
 "<table>" \
 "<tr><td>请输入用户名</td><td><input type=&#39;text&#39; name=&#39;username&#39;/></td></tr>" \
 "<tr><td>请输入密码</td><td><input type=&#39;password&#39; name=&#39;password&#39;/></td></tr>" \
 "<tr><td><input type=&#39;submit&#39; value=&#39;登录&#39;/></td></tr>" \
 "</table>" \
 "</post>"
 return html
ログイン後にコピー

test と 123 を入力すると、ログインが正常に表示されます

機能的には、もちろん、次のようになります。実装されていますが、他の側面から見ると、js スクリプトや css スタイルシートを考慮しないとしても、単純なメンテナンスの観点からは悪夢のようなプログラムであるとは言い難いです。 、確認コードボックスを追加する、それが楽しい仕事だとは思わない人もいます。

そのため、まず、ページの HTML 部分を分離する必要があります。これを実現するために、flask は jinja2 テンプレート エンジンを提供します。

jinja2 テンプレート エンジンは、flask の最も基本的な規則にも準拠しています。つまり、多くの設定に基本的なデフォルト値があります。jinja2 と比較して、最も重要なデフォルト値が 1 つあります。それは、テンプレート ファイルが次の場所に配置されることです。このフォルダーはカスタマイズできますが、今のところデフォルト値で十分です。

まず、PyCharm のプロジェクト ルート ディレクトリに templates フォルダーを作成し、そのフォルダー内に login.html ファイルを作成します。もちろん、ディレクトリ構造は次のとおりです。

ログインにコードを入力します。 html は次のようになります。

@app.route("/login",methods=["POST"])
def loginPost():
 username=request.form.get("username","")
 password=request.form.get("password","")
 if username=="test" and password=="123" :
 return "登录成功"
 else:
 return "登录失败"
ログイン後にコピー

コード これは非常にシンプルであり、スタイルの点で美化されているわけではありません。実際、私に関する限り、知的な認識という理由だけで、使用する十分な理由があります。次に、default.py のログイン メソッドを変更すると、コードは次のようになります。

<!DOCTYPE html>
<html>
 <head>
 <title>欢迎您登陆--牛博客</title>
 </head>
 <body>
 <form method=&#39;post&#39;>
 <table>
 <tr><td>请输入用户名</td><td><input type=&#39;text&#39; name=&#39;username&#39;/></td></tr>
 <tr><td>请输入密码</td><td><input type=&#39;password&#39; name=&#39;password&#39;/></td></tr>
 <tr><td><input type=&#39;submit&#39; value=&#39;登录&#39;/></td></tr>
 </table>
 </form>
 </body>
</html>
ログイン後にコピー

HTML テンプレート内のコードは、py ファイルに直接記述されたものと同じなので、この時点でページを更新し、表示効果は以前と同じになります 表示効果に大きな変更はありませんが、この時点で HTML 内の特定の要素を変更すると、さらに便利になります。

jinja2 テンプレート エンジンについては、インデックスを使用していくつかの命令を作成するなど、いくつかのより強力な機能もサポートしています:

基本的な使用法


default.py のコードの一部を次のように変更します:

from flask import render_template #头部,引入模板渲染方法

@app.route("/login",methods=["GET"])
def login():
 return render_template("/login.html") 

 #渲染模板,默认找templates文件夹下的login.html文件
ログイン後にコピー

index 内のコード。 html は次のとおりです。

from flask import render_template #页头,导入渲染函数

@app.route("/")
def index():
 return render_template("index.html",site_name=&#39;myblog&#39;)
ログイン後にコピー

flask の render_template 関数は複数のパラメーターをサポートしています。関数の最初のパラメーターはテンプレート名であり、その後、変数のデータを提供するために、すべてキーと値のペアであるいくつかのパラメーターを指定できます。テンプレート。この例では、myblog の値が site_name に提供され、{{パラメータ名}} が変数を表すためにテンプレート内で使用されています

このとき、ブラウザの入力アドレスの出力結果は次のようになります:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>{{site_name}}</title>
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
ログイン後にコピー

jinja2 テンプレートも提供しますコードなどのいくつかの変数フィルター:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>myblog</title>
</head>
<body>
<h1>这个站点的名字为 myblog </h1>
</body>
</html>
ログイン後にコピー

出力は次のとおりです:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>{{site_name|upper}}</title>
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
ログイン後にコピー

一般的に使用されるフィルターは次のとおりです

safe はエスケープしません

capitalize は最初の文字を大文字にします

lower は小文字に変換しますupper は大文字に変換します
trim末尾のスペースを削除します
striptages HTML タグを削除します


さらに、Jinja2 変数はいくつかの複合型にすることもでき、次のような複合型の一般的なメソッドを使用することもできます。ステートメント

コントロール ステートメントはテンプレートの基本機能であり、jinja2 は対応する関数も提供します:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>MYBLOG</title>
</head>
<body>
<h1>这个站点的名字为 myblog </h1>
</body>
</html>
ログイン後にコピー

これらの基本的な使用法に加えて、テンプレートは、次のコードを記述するなど、一部のコードを再利用するためのマクロ関数も提供します。

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>{{site_name[2:]}}</title> 
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
ログイン後にコピー
で、macros.html ファイルに入力します。
<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>blog</title>
</head>
<body>
<h1>这个站点的名字为 myblog </h1>
</body>
</html>
ログイン後にコピー
実行結果は前とまったく同じです

Jinja2 は、より強力な機能、つまりテンプレートの継承も提供します。これは個人的には Java の sitemesh に少し似ていると感じます。まず、base.html のベース テンプレートを作成する必要があります:

//选择
{% if name==&#39;test&#39; %}
 这是测试
{% else %}
 {{name}},你好
{% endif %}

//循环
<ul>
 {% for blog in blogs%}
 {{ blog.title }}
 {% endfor%}
</ul>
ログイン後にコピー

この例では、変更可能な部分は、サブテンプレート内で変更できることを意味します。以下はサブテンプレートのコードです:

{% macro render_title(blog)%}
 <li>{{blog.title}}</li>
{% endmacro%}
ログイン後にコピー

この時点での実行結果は次のとおりです:

{% import &#39;macros.html&#39; as macros %}
<ul>
 {% for blog in blogs %}
 {{ macros.render_title(blog) }}
 {% endfor %}
</ul>
ログイン後にコピー

これでテンプレート エンジンができたので、いずれにせよ、ページ レイヤーのためだけにいくつかの優れた関数を作成するのは簡単です。しかし、明らかに、現在のインターフェイスはまだあまり美しくありません。次の章では、現在の主流のフロントエンド フレームワークのブートストラップとフラスコ フレームワークを統合します。

以上がテンプレートエンジンとフォームプラグイン(Python)の詳しい使用例を教えます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート