flask前端套用網(wǎng)頁模板(flask web開發(fā)實戰(zhàn) 入門 pdf)
今天給各位分享flask前端套用網(wǎng)頁模板的知識,其中也會對flask web開發(fā)實戰(zhàn) 入門 pdf進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關(guān)注本站,現(xiàn)在開始吧!
本文目錄一覽:
- 1、Flask博客實戰(zhàn) - 實現(xiàn)全站導航菜單及首頁數(shù)據(jù)展示
- 2、flask里面怎么嵌套html
- 3、使用flask進行前端后臺的數(shù)據(jù)交互
- 4、python-flask 后臺傳遞用戶信息顯示在html中
- 5、[Follow Study] Day1:Flask開發(fā)IDE及入門例子
Flask博客實戰(zhàn) - 實現(xiàn)全站導航菜單及首頁數(shù)據(jù)展示
我們博客的設(shè)計是全站頂部菜單為通用菜單,調(diào)用的數(shù)據(jù)為文章的分類,那么如何將文章分類數(shù)據(jù)傳遞到每個頁面的上下文呢?
為了將新變量自動注入模板的上下文中,F(xiàn)lask 中存在上下文處理器context_processor。上下文處理器在呈現(xiàn)模板之前運行,并且能夠?qū)⑿轮底⑷肽0迳舷挛?。上下文處理器是返回字典的函?shù)。然后,對于應用程序中的所有模板,此字典的鍵和值將與模板上下文合并:
用法如下所示,這只是一個例子:
上面的上下文處理器是一個名為 user 的變量在模板中可用,其值為 g.user。這個例子不是很有趣,因為g無論如何都可以在模板中使用,但它給出了它是如何工作的。
變量不限于值;上下文處理器還可以使函數(shù)可用于模板(因為Python允許傳遞函數(shù)):
上面的上下文處理器使format_price函數(shù)可用于所有模板:
您還可以將format_price構(gòu)建為模板篩選器,但這演示了如何在上下文處理器中傳遞函數(shù)。
知道了上下文處理器的用法,實現(xiàn)這個功能就非常簡單了!
在RealProject目錄的__init__.py中插入如下一個上下文回調(diào)函數(shù)
這個函數(shù)通過limit()方法查詢出前6個數(shù)據(jù),并通過一個字典返回,之后我們還需要將該回調(diào)函數(shù)注冊到app的工廠函數(shù)當中!
在app/blog/templates/base.html中循環(huán)查出我們返回的數(shù)據(jù)即可
在app/blog/views.py文件中的index首頁視圖函數(shù)中實現(xiàn)
這個視圖函數(shù)中的查詢邏輯在實現(xiàn)文章管理的時候已經(jīng)實現(xiàn)過,這里唯一不同的區(qū)別就是我給這個返回數(shù)據(jù)新增了一個img的屬性,因為在數(shù)據(jù)庫我們沒有設(shè)計文章形象圖字段,我們用這種方式彌補,在imgs的列表中預設(shè)一些圖片的url地址,之后隨機抽取一個賦值給img屬性,這樣在模板中直接調(diào)用這個img屬性就會獲取到圖片的url!
在app/blog/templates/base.html中替換相關(guān)循環(huán)數(shù)據(jù)
flask里面怎么嵌套html
可以向模板(template)傳遞多個參數(shù)或者把全部的本地參數(shù)傳遞給template:1.傳遞多個參數(shù)給template,直接將參數(shù)放在render_template()函數(shù)里面,參數(shù)間用逗號隔開:@app.route('/')defindex():content='..'user='Micheal'returnrender_template('index.html',var1=content,var2=user)template中可以直接使用{{var1}}和{{var2}}直接操作變量。2.傳遞全部的本地變量給template,使用**locals():@app.route('/')defindex():content='..'user='Micheal'returnrender_template('index.html',**locals())template中可以直接使用{{content}}和{{user}}直接操作變量。
使用flask進行前端后臺的數(shù)據(jù)交互
flask是一個輕量級的web框架,下面整理講一下如何使用
其實步驟很簡單
1,初始化
app = Flask( name ),創(chuàng)建flask對象app,flask類的構(gòu)造器必須指定的參數(shù),如果是model的話,括號里就放model名,如果是單獨應用可以使用 name 。
在初始化之后,用config.update或者.debug兩種方式來定義是否debug的參數(shù)。線上程序為了安全需將這個參數(shù)設(shè)置為false,也就是不讓debug
2,路由
通過裝飾器的方式將我們的方法轉(zhuǎn)換為路由,具體方法如下:
3,前后端的交互方式
方式一:前端發(fā)送,后端接收
前端通過ajax或者form的submit來生成后端所需要的內(nèi)容(ajax看上一頁)
后端通過request.form來獲取前端post的參數(shù)
方式二:后端發(fā)送,前端接收
后端通過模版引擎render_template來進行交互
后端通過return render_template(’hello.html’, name=name)來向hello.html頁面進行name的傳遞
Html頁面放的地址必須在templates文件夾下。
前端獲取方式:
{% if name %}
h1Hello {{ name }}!/h1
python-flask 后臺傳遞用戶信息顯示在html中
用法:
1.導入render_template函數(shù)
2.當你創(chuàng)建完成flask項目后,會自動生成static文件夾用來放css,js文件,templates文件夾放html文件。在templates文件夾下新建index.html文件
3.在app.py中渲染html,templates文件夾是自動生成的,當使用render_template渲染html時,它會自動去templates文件夾下找,所以這里不用謝文件夾名字,直接寫html的名字就可以。
效果圖
在網(wǎng)頁中用戶登錄后,顯示用名字,就是后臺向前端界面?zhèn)鬟f用戶的信息,前端接收到后顯示出來。
用法:在渲染模板時將參數(shù)寫在后面
在html文件中獲取參數(shù),讀取值使用{{參數(shù)名}}
當傳遞參數(shù)較多時,將它們放在字典中,然后使用**字典名進行傳遞
讀取方法還相同
補充:如果字典中有對象,要在html中獲取對象的屬性值,{{對象名.屬性}},如果字典中還有字典,同樣獲取值使用{{字典名.屬性}}
[Follow Study] Day1:Flask開發(fā)IDE及入門例子
前幾天在進行flask web開發(fā)的時候,雖然照貓畫虎能夠?qū)懸恍┖唵蔚某绦颍贿^感覺基礎(chǔ)有點薄弱,經(jīng)常寫著寫著就卡殼,很尷尬,所以打算先根據(jù)網(wǎng)上的一些開發(fā)教程認真學習學習,打好基礎(chǔ),畢竟磨刀不誤砍柴!
Flask IDE配置相關(guān)
1、virtualenv的使用
virtualenv簡單的理解就是一個虛擬環(huán)境,之所以用這個是為了避免不同的開發(fā)環(huán)境由于python版本而帶來的影響,一句話,避免互相干擾。
virtualenv安裝命令
pip install virtualenv
virtualenv搭建環(huán)境命令
virtualenv venv
這里需要注意,最好安裝在開發(fā)項目目錄下,比如我們的開發(fā)目錄為followstudy,進入這個目錄后,然后在命令行執(zhí)行。其中venv為虛擬環(huán)境的名稱,你也可以起名為其他的。安裝成功之后的目錄結(jié)構(gòu)如下圖:
安裝成功之后,我們需要對項目指定開發(fā)環(huán)境(叫法可能有點問題),具體的話在pycharm的File-default setting中查找。
virtualenv環(huán)境啟用
source venv/bin/activate
啟用的時候,命令不是固定的,這個命令的venv是可變的,具體的話取決于我們的虛擬環(huán)境的命名,總之一句話,需要激活虛擬環(huán)境下的bin目錄下的activate,啟用成功之后,我們可以看到當前命令行前面有一個(venv),以后開發(fā)的過程需要先激活這個虛擬環(huán)境,然后再進行,另外當我們不需要虛擬環(huán)境的話,可以直接在當前命令下輸入:deactivate,這樣就退出了當前的虛擬環(huán)境。
flask安裝命令
pip install flask
在當前虛擬環(huán)境下使用上面的命令,可以快速安裝flask及flask所依賴的包。
flask render_template
上面的index函數(shù)是簡單的一些字符串,顯然并不是很漂亮的,這個時候我們可能需要用到flask的模板引擎——jinja2,jinja2功能比較強大,我們先根據(jù)例子簡單來一個。默認的情況下flask模板文件存放在app下的templates,一個就不建議大家隨意起名字了,約定俗成!首先我們在app文件下建立一個templates目錄,然后在這個目錄下建立一個index.html的文件。
@app.route('/')
def index():
return render_template('index.html', title="hello world")
if name == ' main ':
app.run(debug=True)
在html文件中,我們把需要展示hello world的地方用 {{ title }}替換就可以,這里可以簡單記憶,sample.py文件中的hello world賦值給變量title,然后在html文件中使用{{ title }}調(diào)用數(shù)據(jù)。
flask route路由
前面簡單地使用了一個app.route('/'),為了更好地理解route,我們需要搭建更多的路由,進一步學習。
新添加了兩個路由,一個是about,另一個是service/ 區(qū)別之處,細心的話可以看到,一個結(jié)尾有“/”,另一個是結(jié)尾沒有“/”的。
當訪問127.0.0.1:5000/about 的時候,能夠出現(xiàn)about頁面的內(nèi)容。
但是當我們訪問127.0.0.1:5000/service的時候,url會自動301重定向到127.0.0.1:5000/service/,然后返回service頁面的內(nèi)容。這是flask路由的一個特性,如果是目錄的話 建議加上"/"。如果是page頁面的話,就沒必要加。
flask url_for
url_for是flask中用于路徑定位的一個東西(不知道我理解的對不對。。。),通常來說url_for主要用作兩個用途,一個是用來做視圖函數(shù)的綁定,另一個是用來定位靜態(tài)資源的。
flask url_for視圖綁定
上面就是今天的學習筆記,明天繼續(xù) 歡迎關(guān)注小蝦的公眾號哈
flask前端套用網(wǎng)頁模板的介紹就聊到這里吧,感謝你花時間閱讀本站內(nèi)容,更多關(guān)于flask web開發(fā)實戰(zhàn) 入門 pdf、flask前端套用網(wǎng)頁模板的信息別忘了在本站進行查找喔。
掃描二維碼推送至手機訪問。
版權(quán)聲明:本文由飛速云SEO網(wǎng)絡(luò)優(yōu)化推廣發(fā)布,如需轉(zhuǎn)載請注明出處。