您好,登錄后才能下訂單哦!
什么是Flask?
Flask是一個Web框架,就是提供一個工具,庫和技術來允許你構建一個Web應用程序.這個Web應用程序
可以是一些Web頁面,博客, wiki ,基于 Web 的日歷應用或商業網站。
Flask依賴模塊:
web服務網關接口(Python Web Server Gateway Interface,縮寫為WSGI
Werkzeug 一個WSGI工具包, 是為python語言定義的web服務器和web應用程序或框架之間的一
種簡單而通用的借口,其他語言也有類似的接口)
jinja2模板引擎
Flask屬于微框架( micro-framework )這一類別,微架構通常是很小的不依賴外部庫的框架.
框架很輕量
更新時依賴小
專注于安全方面的bug
from flask import Flask
app = Flask(__name__) #導入Flask對象
@app.route('/') #把修飾的函數注冊為路由
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run()
要給url添加變量部分,可以把這些特殊的字符標記為<variable_name> 這部分將會作為命名參數傳遞到你的函數
from flask import Flask
app = Flask(__name__) #創建對象
@app.route('/')
def hello_world():
return 'Hello World'
@app.route('/user/<username>')
def show_user_profile(username):
# 顯示該用戶名的用戶信息
return 'User %s' % username
@app.route('/post/<int:post_id>')
def show_post(post_id):
# 根據ID顯示文章,ID是整型數據
return 'Post %d' % post_id
if __name__ == '__main__':
app.run()
運行程序將瀏覽器地址修改成 http://127.0.0.1:5000/user/歷史
則顯示:
如果flask能匹配url,那末你可以用url_info()來給指定的函數
構建url ,他接收函數名作為第一個參數,也接受對應url規則的變量部分的命名參數,未知變量部分會添加到url末尾作為查詢參數
from flask import Flask , url_for
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'Hello World!'
@app.route('/user/<username>')
def show_user_profile(username):
# 顯示該用戶名的用戶信息
return 'User %s' % username
@app.route('/post/<int:post_id>')
def show_post(post_id):
# 根據ID顯示文章,ID是整型數據
return 'Post %d' % post_id
@app.route('/url/')
def get_url():
# 根據ID顯示文章,ID是整型數據
return url_for('show_post',post_id=2)
if __name__ == '__main__':
app.run(debug=True)
瀏覽器訪問url:
當用戶訪問程序的根地址時,我們的視圖函數會向客
戶端返回一行HTML代碼。然而,一個完整的HTML頁面往往需要幾十
行甚至上百行代碼,如果都寫到視圖函數里,那可真是個噩夢。這樣的
代碼既不簡潔也難于維護,正確的做法是把HTML代碼存儲在單獨的文
件中,以便讓程序的業務邏輯和表現邏輯分離,即控制器和用戶界面的
分離。
在動態Web程序中,視圖函數返回的HTML數據往往需要根據相應
的變量(比如查詢參數)動態生成。當HTML代碼保存到單獨的文件中
時,我們沒法再使用字符串格式化或拼接字符串的方式來在HTML代碼
中插入變量,這時我們需要使用模板引擎(template engine)。借助模
板引擎,我們可以在HTML文件中使用特殊的語法來標記出變量,這類
包含固定內容和動態部分的可重用文件稱為模板(template)。
模板引擎的作用就是讀取并執行模板中的特殊語法標記,并根據傳
入的數據將變量替換為實際值,輸出最終的HTML頁面,這個過程被稱
為渲染(rendering)。Flask默認使用的模板引擎是Jinja2,它是一個功
能齊全的Python模板引擎,除了設置變量,還允許我們在模板中添加if
判斷,執行for迭代,調用函數等,以各種方式控制模板的輸出。對于
Jinja2來說,模板可以是任何格式的純文本文件,比如HTML、XML、
CSV、LaTeX等
在該文件下創建templates文件夾,然后創建2個文件,分別命名為index.html和user.html 然后render.py 渲染這些模板
from flask import Flask, render_template
app= Flask(__name__)
@app.route('/')
def hello_world():
return render_template('index.html',name='經驗')
@app.route('/user/<username>')
def show_user_profile(username):
# 顯示該用戶名的用戶信息
return render_template('user.html', name=username)
if __name__ == '__main__':
app.run(debug=True)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>hello, {{ name }}!</h2>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>hello {{ name }} </h2>
</body>
</html>
瀏覽器:
利用Jinja2這樣的模板引擎,我們可以將一部分的程序邏輯放到模
板中去。簡單地說,我們可以在模板中使用Python語句和表達式來操作
數據的輸出。但需要注意的是,Jinja2并不支持所有Python語法。而且
出于效率和代碼組織等方面的考慮,我們應該適度使用模板,僅把和輸
出控制有關的邏輯操作放到模板中。
Jinja2允許你在模板中使用大部分Python對象,比如字符串、列
表、字典、元組、整型、浮點型、布爾值。它支持基本的運算符號
(+、-、*、/等)、比較符號(比如==、!=等)、邏輯符號(and、
or、not和括號)以及in、is、None和布爾值(True、False)。
Jinja2提供了多種控制結構來控制模板的輸出,其中for和if是最常用
的兩種。在Jinja2里,語句使用{%...%}標識,尤其需要注意的是,在語
句結束的地方,我們必須添加結束標簽:
{% if user.bio %}
<i>{{ user.bio }}</i>
{% else %}
<i>This user has not provided a bio.</i>
{% endif %}
在這個If語句里,如果user.bio已經定義,就渲染{%if user.bio%}和
{%else%}之間的內容,否則就渲染{%else%}和{%endif%}之間的默認內容。末尾的{%endif%}用來聲明if語句的結束,這一行不能省略。
和在Python里一樣,for語句用來迭代一個序列:
<ul>
{% for movie in movies %}
<li>{{ movie.name }} - {{ movie.year }}</li>
{% endfor %}
</ul>
{{ 變量名| 函數調用 }}
{{ name }}
{{ url_for() }}
{{ get_flshed_messages() }}
"hello".lower()
safe 渲染值時不轉義
capitalize 把值的首字母轉換成大寫,其他字母轉換成小寫
lower 把值轉換成小寫形式
upper 把值轉換成大寫形式
title 把值中每個單詞的首字母都轉換成大寫
trim 把值的首尾空格去掉
striptags 渲染之前把值中所有的 HTML 標簽都刪掉
{% for i in li%}
xxx
{% endfor %}
{% if user == 'westos'%}
xxxx
{% elif user == 'hello' %}
xxx
{% else %}
xxx
{% endif%}
<!--相當于python里面的定義函數, 后面使用的場景: 分頁顯示-->
{% macro render(id) %}
<h2>hello world {{ id }}</h2>
{% endmacro %}
<!--調用定義好的宏(類似于python中的函數)-->
{{ render(1) }}
{{ render(2) }}
{{ render(3) }}
一般網站的導航欄和底部不會變化, 為了避免重復編寫導航欄信息;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{% block title %} {% endblock %}</title>
</head>
<body>
<div > 這是導航欄</div>
{% block body %}
hello
{% endblock %}
<div >這是底部</div>
</body>
</html>
- 如何繼承基模板?
{% extends '06_base.html'%}
{% block title %}
繼承案例
{% endblock %}
{% block body %}
<span >這是最新填的block內容</span>
{% endblockfrom flask import Flask, render_template
例:模板繼承py:
app = Flask(__name__)
@app.route('/')
def index():
return render_template('index.html')
@app.route('/bbs/')
def bbs():
return render_template('bbs.html')
@app.route('/blog/')
def blog():
return render_template('blog.html')
if __name__ == '__main__':
app.run(port=5002) %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{% block title %} {% endblock %}</title>
<style>
.nav{
width: 100%;
height: 50px;
border: 1px solid red;
}
.left{
width: 20%;
border: 1px solid red;
float: left;
height: 100px;
}
.right{
width: 79%;
border: 1px solid green;
float: left;
height: 100px;
}
</style>
</head>
<body>
<div class="nav">
導航欄
<button>登錄</button>
<button>注冊</button>
</div>
<div class="left">
{% include 'left.html' %}
</div>
<div class="right">
{% block body %}
{% endblock %}
</div>
</body>
</html>
{% extends 'base.html' %}
{% block title %}
論壇
{% endblock %}
{% block body %}
<h2>bbs</h2>
{% extends 'base.html' %}
{% block title %}
博客
{% endblock %}
{% block body %}
<h2>blog</h2>
{% extends 'base.html' %}
{% block title %}
主頁
{% endblock %}
{% block body %}
<h2>index</h2>
<ul>
<li>新聞</li>
<li>財經</li>
<li>八卦</li>
<url>
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。