DEDE模板中如何使用if進(jìn)行多分支判斷的教程
我們?cè)谟胐ede做模板的時(shí)候,經(jīng)常會(huì)遇到需要根據(jù)某個(gè)條件判斷來(lái)分別顯示不同的內(nèi)容的情況,也就是dede模板中的多分支判斷。比如典型的,我們需要根據(jù)風(fēng)險(xiǎn)管理數(shù)據(jù)庫(kù)表中的風(fēng)險(xiǎn)等級(jí)字段risklevel的取值的不同分別顯示不同的風(fēng)險(xiǎn)提示圖標(biāo)。如圖1 所示。

紅色框中的投資項(xiàng)目名稱(chēng)前面的圖標(biāo)表示了不同的風(fēng)險(xiǎn)等級(jí),一共有AA,D,E,HR 4個(gè)風(fēng)險(xiǎn)等級(jí)。在數(shù)據(jù)庫(kù)表中保存的分別是這4個(gè)等級(jí)取值中的一個(gè),如圖2 所示。

我們的風(fēng)險(xiǎn)等級(jí)字段risklevel 是可以在列表模板中獲取到其取值的,因?yàn)槲覀冊(cè)趦?nèi)容模型中已經(jīng)設(shè)置了該字段允許被在列表模板中取值。
如圖 3 所示。

這樣,我們?cè)诹斜砟0逯芯秃苋菀淄ㄟ^(guò)
{dede:listpagesize='10'}
[field:risklevel/]
{/dede:list}
來(lái)得到風(fēng)險(xiǎn)等級(jí)的取值。
但是我們不同風(fēng)險(xiǎn)等級(jí)對(duì)應(yīng)的提示圖標(biāo)卻位于圖片目錄下,而且這些提示圖片文件的名稱(chēng)沒(méi)有任何規(guī)律,那么我們就需要通過(guò)if判斷來(lái)根據(jù)風(fēng)險(xiǎn)等級(jí)的不同取值來(lái)設(shè)置不同的提示圖片路徑。
那么應(yīng)該如何來(lái)判斷呢?
需要使用到[field:array]標(biāo)簽,那么我們?cè)撊绾蝸?lái)判斷呢?我們首先要向大家介紹一個(gè)非常有用的dede標(biāo)簽:[field:array] 標(biāo)簽,該標(biāo)簽是標(biāo)簽 {dede:field name='array' /}的簡(jiǎn)寫(xiě)形式,該標(biāo)簽用在列表標(biāo)簽內(nèi)部,例如:{dede:list}標(biāo)簽, {dede: arclist}等標(biāo)簽內(nèi)部。 我們知道,在列表標(biāo)簽內(nèi)部我們可以通過(guò)[field:字段名/]的形式得到某個(gè)數(shù)據(jù)庫(kù)表字段的取值,那么當(dāng)我們想要進(jìn)行分支判斷的時(shí)候,例如:根據(jù)風(fēng)險(xiǎn)等級(jí)取值的不同得到不同的圖標(biāo)路徑,這個(gè)時(shí)候我們就必須借助[field:array] 標(biāo)簽了,[field:array] 標(biāo)簽標(biāo)簽代表查詢得到的數(shù)據(jù)庫(kù)表中的一條記錄,具體的判斷代碼如下:
[field:array runphp='yes']
if(@me['risklevel']=="HR")@me="HR.png";
else if(@me['risklevel']=="D")@me="D.png";
else if(@me['risklevel']=="AA")@me="AA.png";
[/field:array]
{/dede:list}
其意思就是說(shuō)如果查詢得到的風(fēng)險(xiǎn)等級(jí)字段的取值是HR,那么將輸出HR.png, 如果查詢得到的風(fēng)險(xiǎn)等級(jí)字段的取值是D,那么將輸出D.png,如果查詢得到的風(fēng)險(xiǎn)等級(jí)字段的取值是AA,那么將輸出AA.png, 這里的HR.png,只是一個(gè)字符串,代表圖片文件所在的位置,你可以設(shè)置成任意的圖片路徑,上面的代碼是一種分支條件輸出語(yǔ)句,@me代表的就是輸出變量,剛進(jìn)入標(biāo)簽field:array時(shí),@me代表數(shù)據(jù)庫(kù)的一條記錄,其數(shù)據(jù)類(lèi)型是數(shù)組,我們根據(jù)其中risklevle的取值來(lái)判斷,從而將@me設(shè)置成不同的值,當(dāng)退出標(biāo)簽field:array時(shí),@me的值就會(huì)被顯示在原位置。
這個(gè)標(biāo)簽的功能非常強(qiáng)大,它適合于我們最常見(jiàn)的場(chǎng)景,當(dāng)我們?cè)谀0屙?yè)面中需要根據(jù)特定的條件來(lái)進(jìn)行if分支判斷來(lái)顯示不同的內(nèi)容時(shí),采用field:array標(biāo)簽將給我們帶來(lái)極大的方便。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
織夢(mèng)dedecms安全漏洞include/common.inc.php漏洞解決方法
據(jù)悉DEDECMS的全局變量初始化存在漏洞,可以任意覆蓋任意全局變量,下面是具體的解決方法,需要的朋友可以參考下2021-05-13織夢(mèng)DEDECMS建立模型、簡(jiǎn)單分表、索引優(yōu)化操作方法
最近因?yàn)槭褂玫膁ede系統(tǒng)考慮后期數(shù)據(jù)量大的問(wèn)題,所以提前將dedecms優(yōu)化一下,應(yīng)對(duì)后期數(shù)據(jù)量大導(dǎo)致后臺(tái)卡等問(wèn)題,這里為大家分享一下,主要是思路對(duì)于新版本的dedecms需要2021-05-12DedeCMS大數(shù)據(jù)負(fù)載性能優(yōu)化方案(簡(jiǎn)單幾招讓你提速N倍)
今天我們分享一下DedeCMS數(shù)據(jù)負(fù)載性能優(yōu)化的方法,因?yàn)槟壳?0w條記錄,導(dǎo)致站點(diǎn)后臺(tái)查詢慢,生成HTML也很吃力,經(jīng)過(guò)下面的優(yōu)化確實(shí)可以提升不少2021-05-12mysql織夢(mèng)索引優(yōu)化之MySQL Order By索引優(yōu)化
最近基于mysql數(shù)據(jù)庫(kù)的織夢(mèng)系統(tǒng)查詢與生成靜態(tài)頁(yè)面比較慢,所以想優(yōu)化一下索引試試能不能提高一下執(zhí)行效率下面是具體的實(shí)現(xiàn)步驟,需要的朋友可以參考一下2021-05-12織夢(mèng)dedecms頁(yè)面空白后開(kāi)啟錯(cuò)誤信息提示功能方便調(diào)試錯(cuò)誤
織夢(mèng)后臺(tái)空白、織夢(mèng)后臺(tái)左側(cè)空白等相關(guān)問(wèn)題,如果沒(méi)有報(bào)錯(cuò)提示信息,不顯示任何內(nèi)容,對(duì)新手來(lái)說(shuō)摸不著頭腦,無(wú)從下手,開(kāi)啟織夢(mèng)錯(cuò)誤信息提示錯(cuò)誤調(diào)試設(shè)置,讓程序告訴我們2021-05-12
織夢(mèng)DedeCMS 分表實(shí)現(xiàn)一個(gè)欄目對(duì)應(yīng)一個(gè)表(圖)
最近考慮用dedecms做個(gè)大數(shù)據(jù)量的網(wǎng)站,為什么用dedecms呢因?yàn)檫@個(gè)系統(tǒng)特別好用,但負(fù)載是軟肋,很多功能只能自己動(dòng)手實(shí)現(xiàn)了,下面就為大家分享一下具體的方法2021-05-12- 這篇文章主要介紹了加固版織夢(mèng)CMS整站源碼通用安裝教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-17
織夢(mèng)DEDECMS robots優(yōu)化設(shè)置的具體方法
這篇文章主要介紹了織夢(mèng)DEDECMS robots優(yōu)化設(shè)置的具體方法,DEDECMS自帶的robots.txt文件設(shè)置很簡(jiǎn)單,并不能完全滿足網(wǎng)站的優(yōu)化要求,需要的朋友可以參考下本篇方法2020-12-02Dedecms網(wǎng)站Title標(biāo)簽SEO優(yōu)化方法
這篇文章主要介紹了Dedecms網(wǎng)站Title標(biāo)簽SEO優(yōu)化方法,主要涉及到如何實(shí)現(xiàn)"三級(jí)欄目_二級(jí)欄目_一級(jí)欄目_網(wǎng)站名稱(chēng)"的問(wèn)題,需要的朋友可以參考下小編的方法2020-12-02dedecms文章關(guān)鍵字(自動(dòng)內(nèi)鏈)php5.5以上版本urf-8失效的解決方法
這篇文章主要為大家詳細(xì)介紹了dedecms文章關(guān)鍵字(自動(dòng)內(nèi)鏈)php5.5以上版本urf-8失效的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,有需要的朋友可以收藏2020-11-18


