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