作者catjimmy (cat)
看板PHP
標題[急問]PHP+MySQL+Smarty 輸出問題
時間Sun Mar 13 22:41:58 2011
對不起,實在想不到一個簡短就能描述我的問題的標題
還請版上高手們能給我一點指引
小弟現在使用Smarty作為樣板引擎,小弟現在想要做的事情闡述如下
我的MySql資料庫中有三個資料表,用彼此的ID作為階層關係如下
project資料表中 有project_no project_name
category資料表中 有 category_no category_name和指向所屬project的project_no
items資料表中 有items_no items_name和指向所屬category的category_no
用這樣的資料庫設定方法很笨我知道@@" 可小弟還是php的新手
暫時對於太高深的做法還不太懂,如果有大大願意指點當然是最好XD
因為很多地方會需要將這些東西全部list出來,因此小弟將他們包裝成一個class
並指定了一個getlist方法
class程式碼如下
class OutputList {
var $ouput_list = array();
function OutputList (&$db) {
$sql = "select * from project left join category on ".
"project.project_no = category.project_no left join items on ".
"category.category_no = items.category_no order by ".
"project.project_no,category.category_no,items.items_no";
$this->ouput_list = &$db->getAll($sql);
}
function getList(){
return $this->ouput_list;
}
}
然後在需要使用的php程式中new出,並指定樣板
//===============================================
// 取得output列表
//===============================================
$output_list_object = new OutputList($db);
$ouput_list = &$output_list_object->getList();
if (DB::isError($output_list_object))
{
header("Content-Type: text/plain; charset=utf-8");
die ($output_list_object->getMessage());
}
//===============================================
// 樣板處理
//===============================================
$smarty = new Template();
$smarty->assign('output_list', $output_list);
//===============================================
// 顯示頁面
//===============================================
$smarty->assign(
'content_file',
'output_list.tpl.htm'
);
$smarty->display('main.tpl.htm');
而樣板output_list.tpl.htm中,輸出的部分如下
{section name="sec1" loop=$output_list}
<tr>
<td width="10%" align="right">{$smarty.section.sec1.iteration}</td>
<td>{$output_list[sec1].project_name}</td>
<td>{$output_list[sec1].category_name}</td>
<td>{$output_list[sec1].items_name}</td>
</tr>
問題來了,這樣的方法很笨我知道@@" 輸出的表格會變成三個階層都顯示
就像是items也會顯示前面的project跟categary
所以我的第一個問題是,可否在不要用到js、jquery之類的動態技術
就可以顯示這筆資料的最後一個階層,如果這筆資料只有到category,
那麼就顯示category就好,不用顯示他的project
簡單來說就是我希望這表格看起來比較有階層關係@@"
第二個問題是,我希望在這表格後方加上一個checkbox
可以讓使用者複選category和items後,將所選的category或是items的no值傳出
但這checkbox僅有category和items才有,project沒有
在Smarty中我知道有HTML_checkboxes可以使用
但我實在沒有一個概念要怎麼樣用出我想要的顯示
以上兩個問題寫的落落長,還請版上高手不吝指教@@" 小弟銘感五內
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 111.241.249.107
1F:→ tkdmaf:我的規則是:除宣告動作、屬性,建構式內不寫任何程式。 03/14 00:00
2F:→ catjimmy:可以問一下這樣有甚麼好處嗎? 結構性? 03/14 14:10
3F:推 walilecow:這個程式看起來只做讀取資料...不用class應該也可以吧 03/14 22:55
4F:→ tkdmaf:建構式為物件實體化時會預先處理的方法。 03/14 23:35
5F:→ tkdmaf:所以一般而言,主要就是用於初始化或預載入功能。 03/14 23:35
6F:→ tkdmaf:你不一定一隻物件會預載入多少方法。 03/14 23:36
7F:→ tkdmaf:在單一職責中,每個方法都會是一個獨立功能的個體。 03/14 23:36
8F:→ tkdmaf:而建構式則只是選擇你想預載入那些個體執行或宣告屬性。 03/14 23:36
9F:→ tkdmaf:一但你因為某些因素需要修改預載方法時才不會被一堆程式碼 03/14 23:37
10F:→ tkdmaf:弄得不知改如何去改。 03/14 23:37
11F:→ tkdmaf:另外一點就是如果善用繼承後覆蓋父類別建構式時...... 03/14 23:38
12F:→ tkdmaf:自己的建構式要載入方法就比較容易處理。 03/14 23:38