這篇文章主要介紹了Thinkphp實現volist標籤嵌套循環的方法,需要的朋友可以參考下
本文較為詳細的對ThinkPHP的volist標籤嵌套的用法闡述如下:
首先,在Thinkphp開發手冊中,有關於3da5ee660f26a047cce0b9503e43e613標籤嵌套的解釋說明。如下:
標籤嵌套:
模板引擎支援標籤的多層嵌套功能,可以對標籤庫的標籤指定可以嵌套。在
系統內建的標籤中,volist(及其別名iterate)、switch、if、elseif、else、foreach、compare(包括所有的比較標籤)、(not)present、(not)empty、(not)defined等標籤都可以嵌套使用。例如:
<volist name="list" id="vo"> <volist name="vo['sub']" id="sub"> {$sub.name} </volist> </volist>
上面的標籤可以用來輸出雙重循環。
預設的巢狀層次是3級,所以巢狀層次不能超過3層,如果需要更多的層次可以指定TAG_NESTED_LEVEL配置參數。
但是在Action中具體應該怎麼賦值「list」呢?從說明中可以看出,list應該是一個二維數組,下邊是一段測試程式碼,經過測試可以使用。
$Baojia=new Model('baojia'); $Class=new Model('class'); $parent=$Class->select(); foreach($parent as $n=> $val){ $parent[$n]['voo']=$Baojia->where('belongto=\''.$val['name'].'\'')->select(); } $this->assign('list',$parent); <volist name="list" id="vo"> {$vo.name}<BR> <volist name="vo['voo']" id="sub"> {$sub.name} </volist><BR> </volist>
資料庫中定義了兩個表,一個是報價表,一個是分類表,實現的功能是像樹形選單一樣,顯示分類,每個分類下邊是各個型號的報價。
程式碼主要功能是:
1.首先建立模型:
$Baojia=new Model('baojia'); $Class=new Model('class');
2.然後查詢分類中的數據,這一步非常重要,因為我們知道,資料庫查詢傳回的是類似表格的二維形式的數據,當我們取出單一資料時,相當與讀取每行資料。當呼叫3da5ee660f26a047cce0b9503e43e613時,thinkphp後台會自動讀取每一行資料。
$parent=$Class->select();
將報價中的資料存入$parent中,其中$n是$parent數組的序號,也就相當於存入$parent中的資料表,每行添加一個索引,這個索引指向屬於這個分類的報價。
foreach($parent as $n=> $val){ $parent[$n]['voo']=$Baojia->where('belongto=\''.$val['name'].'\'')->select(); }
3.最後:
$this->assign('list',$parent);
顯示輸出!
透過這個程序,可以更深入的理解3da5ee660f26a047cce0b9503e43e613標籤,其實如果在資料庫操作中,3da5ee660f26a047cce0b9503e43e613標籤的name只能assign 成資料庫表型別(當然也可以是陣列型,因為資料庫查詢得到的資料本身就是數組型的),當我們在視圖頁面調用3da5ee660f26a047cce0b9503e43e613標籤時,特別是嵌套調用時,始終記住每一層的name都必須是數組型的,像本程式中,最外層,2c7953a8f6f793cfefe6eaa0b0257de7這裡的list就是我們最初定義的$parent,這個變數指向查詢class表得到的資料表,裡層ec18395323f098c05bac9744d0206609,也就是$parent[$n]['voo']所指向的資料表,也就是報價表中對應的資料。
透過這樣的分析,條理已經很清楚了,舉一反三就可以實現N重循環,當然如果需要更多的層次可以指定TAG_NESTED_LEVEL配置參數。
這樣的話,就可以實現例如:國家->省->市->縣->鄉鎮等多重循環
相關推薦:
#
以上是Thinkphp的volist標籤嵌套循環使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!