<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                {% raw %} # Flask 教程:模板 > 原文: [https://pythonbasics.org/Flask-Tutorial-Templates/](https://pythonbasics.org/Flask-Tutorial-Templates/) 模板可幫助您重用視覺效果。 在所有 Web 應用程序中,視覺效果都可以重復使用。 這可以幫助您劃分業務和表示邏輯。 您不希望您的應用程序代碼與圖形設計代碼混合在一起。 想象一下一個分析應用程序。 您希望每個頁面上都有相同的導航和頁腳。 內容可能有所不同,但總體設計保持不變。 這是通過模板完成的。 ## 模板示例 您要做的第一件事是為模板創建目錄。 您可以使用以下命令從終端執行此操作。 如果尚未這樣做,請[創建一個應用](https://pythonbasics.org/Flask-Tutorial-Hello-World/)。 假設您的項目目錄名為`app`, ```py (venv) $ mkdir app/templates ``` 單個模板只是一個文件。 每個模板都包含 HTML 代碼,這是 Web 的標準語言。 ### Flask 模板變量 讓我們創建文件`index.html` ```py <html> <head> <title>{{ title }}</title> </head> <body> <h1>Hello {{ username }}</h1> </body> </html> ``` 其中大多數是 HTML 標記(在`<`和`>`符號之間),這是網絡上的標準標記。 那么,那些 `{{` 和 `}}` 符號是什么? 這是在網頁上顯示 Python 變量的方式。 它們是要顯示的變量的占位符。 在此模板中,可以傳遞兩個變量:標題和用戶名。 ## 模板渲染 要知道的關鍵事情之一是,模板用于將業務邏輯與表示邏輯分開。 這樣可以提高軟件的可維護性,可擴展性和可移植性。 可以從您的 Python 代碼中傳遞變量。 Python 需要渲染模板,因此需要導入模板。 ```py from flask import render_template ``` 更改原始代碼: ```py @app.route('/') def index(): return 'Web App with Python Flask!' ``` 進入渲染模板并傳遞變量的代碼: ```py @app.route('/') @app.route('/index') def index(): name = 'Rosalia' return render_template('index.html', title='Welcome', username=name) ``` 然后啟動應用程序: ```py sudo python3 app.py ``` 然后它將在終端中顯示一些文本: ```py * Serving Flask app "app" (lazy loading) * Environment: production WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead. * Debug mode: off * Running on http://0.0.0.0:81/ (Press CTRL+C to quit) ``` 并在 Web 瀏覽器中打開終端中顯示的 URL。 ## `render_template` 在上面的示例中,您調用了函數`render_template()`。 為什么要調用此方法而不立即返回 html 數據? Flask 與一種名為 [Jinja2](https://palletsprojects.com/p/jinja/) 的語言捆綁在一起。 這使您能夠直接在模板中包含變量,創建循環和添加`if`語句。 在上面的示例中,您已經了解了如何包含`title`和`username`之類的變量。 那么,如何包含循環和`if`語句? ![jinja flask template engine](https://img.kancloud.cn/96/f4/96f4b5685cf6885fb1a7a5797db15381_831x168.jpg) ## Flask 模板`if` 您可以在模板中包含`if`語句。 可以使用與 Python 中相同的運算符(`==`,`>`,`<`,`>=`,`<=`)。 也可以使用`else`或`elif`之類的子句。 在此代碼中,輸出將根據輸入變量用戶名而有所不同。 用戶名通過 Python 代碼(業務邏輯)傳遞到模板(表示邏輯)。 ```py <html> <head> <title>{{ title }}</title> </head> <body> {% if username == "Rosalia": %} <h1>Hello my love</h1> {% else %} <h1>Hello {{ username }}</h1> {% endif %} </body> </html> ``` ## Flask 模板`for`循環 如果您有大量數據(例如用戶列表),則希望使用`for`循環對其進行迭代。 將 Python 代碼更改為此: ```py @app.route('/') @app.route('/index') def index(): users = [ 'Rosalia','Adrianna','Victoria' ] return render_template('index.html', title='Welcome', members=users) ``` 該代碼包括一個列表(用戶)。 該列表將傳遞給`render_template`函數。 在模板中,可以使用`for`循環遍歷列表。 ```py <html> <head> <title>{{ title }}</title> </head> <body> <ul> {% for member in members: %} <li>{{ member }}</li> {% endfor %} </ul> </body> </html> ``` 對于代碼,使用標簽 `{%` 和 `%}` 。 要顯示變量,請寫入標簽 `{{` 和 `}}` 。 ![for loop in jinja2](https://img.kancloud.cn/96/52/96528bd7b0d3c111e8f26e8f38739374_514x275.jpg) [**下載示例**](https://gum.co/IMzBy) {% endraw %}
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看