我之所以這麼喜歡Zend Framework的關係,
其中一項就是它可以幫你很簡單的實現MVC的架構,
所以今天的任務就是要建立一個以MVC為架構的基本網頁。
首先當然要先建立一個測試用的資料庫,
因此我簡單的建立了一個名為Employee的資料表來進行展示,
該資料表如下:
很簡單的資料表吧,就三個欄位而已,
這我想我就應該不用多做解釋了,
只是拿來存放員工姓名與年紀資料而已。
好了,有了資料之後就能開始建立Model了,
首先在src\Application\下建了一個Model的資料夾,
並分別建立其ValueObject和Model的類別檔,
我先建立一個ValueObjec(src\Application\Model\Employee.php)給大家看:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
namespace Application\Model; class Employee { public $emp_id; public $emp_name; public $emp_age; public function exchangeArray($data) { $this->emp_id = (isset($data["emp_id"]))?$data["emp_id"]:null; $this->emp_name = (isset($data["emp_name"]))?$data["emp_name"]:null; $this->emp_age = (isset($data["emp_age"]))?$data["emp_age"]:null; } } |
這段ValueObject的程式碼應該沒有太大的問題,
唯一你會覺得怪怪的應該就是那個exchangeArray,
那個其實是要給之後Model用的方法,
所以你可以先暫時不理他,只要知道他的任務是用來為資料用的。
完成ValueObject之後,我們就可以開始介入建立一個新的Model,
所以建立一個新的Model(src\Application\Model\EmployeeTable.php):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
namespace Application\Model; use Zend\Db\Adapter\Adapter; use Zend\Db\ResultSet\ResultSet; use Zend\Db\TableGateway\AbstractTableGateway; class EmployeeTable extends AbstractTableGateway { protected $table = "Employee"; public function __construct(Adapter $adapter) { $this->adapter = $adapter; $this->resultSetPrototype = new ResultSet(); $this->resultSetPrototype->setArrayObjectPrototype(new Employee()); $this->initialize(); } public function fetchAll() { $resultSet = $this->select(); return $resultSet; } public function getEmployee($id) { $id = (int)$id; $rowSet = $this->select(array("emp_id"=>$id)); $row = $rowSet->current(); return $row; } public function saveEmployee(Employee $employee) { $data = array("emp_name"=>$employee->emp_name, "emp_age"=>$employee->emp_age); $this->insert($data); } public function deleteEmployee($id) { $this->delete(array("emp_id"=>$id)); } } |
你有沒有看到建構函數時會執行setArrayObjectPrototype這個方法,
這時候裡面new了一個Employee作為其參數,
目的就是要將吐回來的資訊用ValueObject進行包裝的動作,
在這個Model中我們時做了幾個搜尋,新增,刪除的方法,
在今天我們只會用到fetchAll這個方法來取出所有資料,
若是有興趣的人可以自己參考我其他寫的資料操作方法。
Model完成後,就可以在Controller去嘗試取出資料,
我們拿出之前所寫好的IndexController來做一個小的展示,
其路徑放在 src\Application\Controller\IndexController.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
namespace Application\Controller; use Zend\Mvc\Controller\AbstractActionController; use Zend\View\Model\ViewModel; class IndexController extends AbstractActionController { protected $employeeTable; public function indexAction() { $serviceManager = $this->getServiceLocator(); $this->employeeTable = $serviceManager->get("Application\Model\EmployeeTable"); $employees = $this->employeeTable->fetchAll(); return new ViewModel(array("employees"=>$employees)); } public function addAction() { return new ViewModel(); } } |
你可以看到我在indexAction的方法中,
先用ServiceManager把Model給載入進來,
接下來就可以使用背實作出來的Model,
透過fetchAll的方法來將資料庫所有員工資料取出,
最後由ViewModel來將資料交給View來進行呈現。
好啦,最後我們只要將View給實作出來就好,
這個應該是整段裡面最簡單的一環,
所以我就直接將code貼出來給大家看,
該View放在 src\view\application\index\index.phtml。
1 2 3 |
foreach ($employees as $employee) { printf("<li>NAME: %s, AGE: %d</li>", $employee->emp_name, $employee->emp_age); } |