欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Python的Flask框架中使用模版的入門教程

 更新時(shí)間:2015年04月20日 12:08:46   投稿:goldensun  
這篇文章主要介紹了在Python的Flask框架中使用模版的入門教程,模版的使用是Flask使用當(dāng)中的基礎(chǔ),需要的朋友可以參考下

 概述

如果你已經(jīng)閱讀過上一個(gè)章節(jié),那么你應(yīng)該已經(jīng)完成了充分的準(zhǔn)備工作并且創(chuàng)建了一個(gè)很簡單的具有如下文件結(jié)構(gòu)的Web應(yīng)用:
 
microblog
    |-flask文件夾
    |-<一些虛擬環(huán)境的文件>
    |-app文件夾
    |  |-static文件夾
    |  |-templates文件夾
    |  |-__init__.py文件
    |  |-views.py文件
    |-tmp文件夾
    |-run.py文件

親,想要運(yùn)行這個(gè)程序么?那就運(yùn)行這個(gè)run.py文件,然后在你的瀏覽器里邊打開http://localhost:5000這個(gè)地址.

我們?cè)诤竺娴恼鹿?jié)會(huì)不斷地從前一章節(jié)結(jié)束的地方繼續(xù)開發(fā)我們的應(yīng)用,所以你要確保你的環(huán)境已經(jīng)正確安裝,并且你的應(yīng)用能夠正常運(yùn)行.
 

為什么我們需要使用模板系統(tǒng)

讓我們來考慮一下,我們接下來怎么樣擴(kuò)展我們的小程序.

我們要在微博應(yīng)用里邊實(shí)現(xiàn)一個(gè)非?;镜墓δ?在首頁上面顯示一個(gè)歡迎已登錄用戶的標(biāo)題.暫且忽略當(dāng)前應(yīng)用里邊沒有用戶的狀況,我將會(huì)在稍后解決這個(gè)問題.

要顯示一個(gè)美觀大方的標(biāo)題,最簡單的方法就是改變我們提供視圖的方式來顯示一些HTML代碼,不如這樣子:\
 

from app import app
 
@app.route('/')
@app.route('/index')
def index():
  user = { 'nickname': 'Miguel' } # fake user
  return '''
<html>
 <head>
  <title>Home Page</title>
 </head>
 <body>
  <h1>Hello, ''' + user['nickname'] + '''</h1>
 </body>
</html>

現(xiàn)在,在你的瀏覽器里面刷新一下看看,是不是很爽?
 

因?yàn)槲覀冞@個(gè)小程序還支持用戶功能,所以咱用了一個(gè)用戶占位對(duì)象,通常它被親切的稱呼為假數(shù)據(jù)或測試數(shù)據(jù)。它可以讓我們關(guān)注程序中急需解決的部分。

爽完了,面對(duì)實(shí)際吧,我希望你會(huì)覺得上面這個(gè)混合著html代碼的小程序相當(dāng)惡心。想想看,如果你用一些動(dòng)態(tài)內(nèi)容生成的一個(gè)復(fù)雜的HTML頁面,并且想要在由這樣的程序組成的網(wǎng)站中改變一些頁面內(nèi)容,這將會(huì)一件非常蛋疼的事情。

模板系統(tǒng)拯救世界

如果保持業(yè)務(wù)邏輯和表現(xiàn)的分離,你的網(wǎng)站結(jié)構(gòu)將會(huì)組織的更好。不要不信,如果你用python完成了業(yè)務(wù)代碼,你甚至可以請(qǐng)一個(gè)網(wǎng)站設(shè)計(jì)師幫你完成剩下的部分。模板系統(tǒng)就是幫你實(shí)現(xiàn)業(yè)務(wù)和表現(xiàn)分離的。

讓我們完成第一個(gè)模板(fileapp/templates/index.html):
 

<html>
 <head>
  <title>{{title}} - microblog</title>
 </head>
 <body>
   <h1>Hello, {{user.nickname}}!</h1>
 </body>
</html>

如你所見,我們只是寫了一個(gè)普通的HTML頁面,唯一跟HTML有區(qū)別的就是里面摻雜了一些以 {{ ... }} 組成的動(dòng)態(tài)內(nèi)容占位符。


現(xiàn)在讓我們來看看視圖函數(shù)中是如何處理這個(gè)模板的(fileapp/views.py):
 

from flask import render_template
from app import app
 
@app.route('/')
@app.route('/index')
def index():
  user = { 'nickname': 'Miguel' } # fake user
  return render_template("index.html",
    title = 'Home',
    user = user)

測試這段程序的重點(diǎn)就是看看模板系統(tǒng)是如何工作的。你可以比較瀏覽器中渲染后的html頁面源碼與模板文件源碼之間的區(qū)別。

在上面的程序中,我們從 Flask 框架 import 了一個(gè)叫 render_template 的新函數(shù),并用這個(gè)函數(shù)來渲染模板。并給這個(gè)函數(shù)賦予了模板文件名和一些變量作為參數(shù)。它將導(dǎo)入的變量替換掉模板中的變量占位符,并返回渲染后的模板。

讓我們了解的更深入點(diǎn)。在 Flask 底層,render_template 函數(shù)實(shí)際上是調(diào)用了 Flask 的一個(gè)組件: Jinja2 模板處理引擎。是 Jinjia2 用導(dǎo)入的變量替換掉了模板中對(duì)應(yīng)的 {{ ... }} 代碼塊。

模板中的流程控制

Jinja2 模板系統(tǒng)還支持流程控制語句,我們來嘗試一下在模板中添加一個(gè) if 流程控制語句 (fileapp/templates/index.html):
 

<html>
 <head>
  {% if title %}
  <title>{{title}} - microblog</title>
  {% else %}
  <title>Welcome to microblog</title>
  {% endif %}
 </head>
 <body>
   <h1>Hello, {{user.nickname}}!</h1>
 </body>
</html>

現(xiàn)在我們的模板文件有點(diǎn)智能了。如果我們?cè)谝晥D函數(shù)中忘了定義頁面標(biāo)題變量 title,它將會(huì)使用自已的標(biāo)題替代。把視圖函數(shù)中 render_template 里的 title 變量取消試試,看看這個(gè) if 流程語句是如何工作的。

模板中使用循環(huán)

也許用戶想在他的主頁上展示好友最近寫的文章,有點(diǎn)像人人,或者新浪微博那樣的好友動(dòng)態(tài),接下來我們就要看看如何來完成這個(gè)功能。

首先,創(chuàng)建用戶和文章 (fileapp/views.py):
 

def index():
  user = { 'nickname': 'Miguel' } # fake user
  posts = [ # fake array of posts
    {
      'author': { 'nickname': 'John' },
      'body': 'Beautiful day in Portland!'
    },
    {
      'author': { 'nickname': 'Susan' },
      'body': 'The Avengers movie was so cool!'
    }
  ]
  return render_template("index.html",
    title = 'Home',
    user = user,
    posts = posts)

用數(shù)組存儲(chǔ)用戶的文章,每一個(gè)數(shù)組元素都是一個(gè)字典,如上代碼所示,這個(gè)dict的key是author和body,用來存儲(chǔ)文章的作者和文章內(nèi)容。當(dāng)我們決定使用數(shù)據(jù)庫來存儲(chǔ)這些信息時(shí),這個(gè)字典的key可以隱射為表的一個(gè)字段,這里為了給大家演示模板的使用,沒有使用數(shù)據(jù)庫相關(guān)的技術(shù),簡單地使用字典和數(shù)組模擬用戶和他的好友最近發(fā)表的文章。
 

我們的模板文件現(xiàn)在有了一個(gè)新問題。我們剛剛創(chuàng)建了一個(gè)包含用戶文章的內(nèi)容數(shù)據(jù),這個(gè)數(shù)組可能包含任意數(shù)量的文章。怎樣才能讓模板根據(jù)這個(gè)數(shù)組的數(shù)量自動(dòng)渲染內(nèi)容。

要解決這個(gè)問題,就需要一個(gè)新的流程控制語句:for循環(huán)。讓我們來把 for循環(huán)添加到模板文件 (fileapp/templates/index.html)
 

<html>
 <head>
  {% if title %}
  <title>{{title}} - microblog</title>
  {% else %}
  <title>microblog</title>
  {% endif %}
 </head>
 <body>
  <h1>Hi, {{user.nickname}}!</h1>
  {% for post in posts %}
  <p>{{post.author.nickname}} says: <b>{{post.body}}</b></p>
  {% endfor %}
 </body>
</html>

很簡單吧,你還可以在數(shù)組中添加更多的內(nèi)容看看效果。
 
模板繼承

接來下,我們需要給這個(gè)微博(microblog)添加一個(gè)導(dǎo)航菜單,里面包含 修改個(gè)人資料,退出登錄 等類似的鏈接。

直接在 index.html 模板文件中直接加入這個(gè)導(dǎo)航條也是可行的,但是當(dāng)我們有很多模板文件都包含這個(gè)導(dǎo)航條時(shí),就會(huì)陷入為了修改導(dǎo)航條的某個(gè)地方而不得不在多個(gè)文件中往返編輯的尷尬境地。當(dāng)包含這個(gè)導(dǎo)航條的文件越來越多時(shí),你想死的心就會(huì)有了。


我們可以使用 Jinja2 的模板繼承功能,它可以使我們把模板中一些公共的內(nèi)容組合在一起創(chuàng)建一個(gè)基礎(chǔ)模板,然后讓其它模板繼承這個(gè)基礎(chǔ)模板。

我們先來定義一個(gè)基礎(chǔ)模板,里面包含了導(dǎo)航條和那個(gè)最開始寫的關(guān)于頁面標(biāo)題(title)的流程控制語句。(fileapp/templates/base.html):
 

<html>
 <head>
  {% if title %}
  <title>{{title}} - microblog</title>
  {% else %}
  <title>microblog</title>
  {% endif %}
 </head>
 <body>
  <div>Microblog: <a href="/index">Home</a></div>
  <hr>
  {% block content %}{% endblock %}
 </body>
</html>

在這個(gè)模板中,我們使用了 block 控制語句來定義繼承模板內(nèi)容的顯示位置。注意:這個(gè) block 語句中設(shè)置的名稱必須唯一。


接下來讓我們修改一下 index.html 模板,讓它繼承于剛剛添加的基礎(chǔ)模板 base.html (fileapp/templates/index.html):

 

{% extends "base.html" %}
{% block content %}
<h1>Hi, {{user.nickname}}!</h1>
{% for post in posts %}
<div><p>{{post.author.nickname}} says: <b>{{post.body}}</b></p></div>
{% endfor %}
{% endblock %}

基礎(chǔ)模板 base.html 幫我們搞定了頁面結(jié)構(gòu)和公共內(nèi)容,所以這個(gè) index.html 模板就成了這幅衰樣了。extends 語句使兩個(gè)模板關(guān)聯(lián)了起來。Jinja2 在渲染 index.html 模板時(shí),發(fā)現(xiàn) extends 語句,就會(huì)自動(dòng)先引入 base.html 基礎(chǔ)模板,并對(duì)兩個(gè)模板中名為 content 的 block 語句進(jìn)行匹配。Jinja2知道如何把兩個(gè)模板合并到一起。我們以后創(chuàng)建新的模板時(shí),同樣也會(huì)使用這種從基礎(chǔ)模板繼承的方法。

結(jié)束語

如果你想節(jié)省時(shí)間,懶得敲代碼,可以從以下地址下載本章內(nèi)容的示例代碼:

下載地址:microblog-0.2.zip

相關(guān)文章

  • python 打印dict的key與value方式

    python 打印dict的key與value方式

    這篇文章主要介紹了python 打印dict的key與value方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Python Tkinter簡單布局實(shí)例教程

    Python Tkinter簡單布局實(shí)例教程

    這篇文章主要介紹了Python Tkinter簡單布局實(shí)例教程,包括了填充、左右布局、絕對(duì)布局、網(wǎng)格布局等,需要的朋友可以參考下
    2014-09-09
  • Python常用內(nèi)置函數(shù)的使用教程詳解

    Python常用內(nèi)置函數(shù)的使用教程詳解

    Python官方文檔對(duì)于內(nèi)置函數(shù)的介紹較為簡略,但這些內(nèi)置函數(shù)在日常工作中卻扮演著不可或缺的角色。這篇文章為大家介紹了Python常用內(nèi)置函數(shù)的使用,需要的可以參考一下
    2023-04-04
  • OpenCV?基本圖形繪制函數(shù)詳解

    OpenCV?基本圖形繪制函數(shù)詳解

    這篇文章主要介紹了OpenCV?基本圖形繪制函數(shù),用于繪制圓的circle函數(shù),用于繪制填充的多邊形的fillPoly函數(shù),本文給大家提到好幾種,通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-12-12
  • Python對(duì)接支付寶支付自實(shí)現(xiàn)功能

    Python對(duì)接支付寶支付自實(shí)現(xiàn)功能

    這篇文章主要介紹了Python對(duì)接支付寶支付自實(shí)現(xiàn)功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 使用python實(shí)現(xiàn)CGI環(huán)境搭建過程解析

    使用python實(shí)現(xiàn)CGI環(huán)境搭建過程解析

    這篇文章主要介紹了使用python實(shí)現(xiàn)CGI環(huán)境搭建過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • python 引用傳遞和值傳遞詳解(實(shí)參,形參)

    python 引用傳遞和值傳遞詳解(實(shí)參,形參)

    這篇文章主要介紹了python 引用傳遞和值傳遞詳解(實(shí)參,形參)。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • PyHacker編寫指南引用Nmap模塊實(shí)現(xiàn)端口掃描器

    PyHacker編寫指南引用Nmap模塊實(shí)現(xiàn)端口掃描器

    這篇文章主要為大家介紹了PyHacker編寫指南Nmap模塊實(shí)現(xiàn)端口掃描,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • python 代碼實(shí)現(xiàn)k-means聚類分析的思路(不使用現(xiàn)成聚類庫)

    python 代碼實(shí)現(xiàn)k-means聚類分析的思路(不使用現(xiàn)成聚類庫)

    這篇文章主要介紹了python 代碼實(shí)現(xiàn)k-means聚類分析(不使用現(xiàn)成聚類庫),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 淺析Python 中整型對(duì)象存儲(chǔ)的位置

    淺析Python 中整型對(duì)象存儲(chǔ)的位置

    下面小編就為大家?guī)硪黄獪\析Python 中整型對(duì)象存儲(chǔ)的位置。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過來看看吧
    2016-05-05

最新評(píng)論