我以OOP方式使用PHP相对较新。在我的最新项目中,我将创建一个站点,该站点将从SQL数据库加载大量条目,然后将这些条目发送到视图以进行输出。
在摆弄如何以最佳方式执行此操作时,我创建了下面列出的代码:
class entryHandler {
//Store database connection
protected $database;
//List of all entries as multidimensional array fetched from SQL.
private $entriesSQL = array();
//List of all entries (as objects) will be stored in our $entries array
private $entriesObjects = array();
/*
*
* Upon construct
*
*/
public function __construct($database) {
//Check if database class has been passed correctly.
//Else we exit, since we can not function without it!
if (isset($database)) {
$this -> database = $database;
//Get events
if ($entriesSQL = $this -> getEventsFromSQL()) {
// Set SQL entries
$this -> setEntriesSQL($entriesSQL);
//And turn them into an array of objects
$this -> setEntryObjects();
}
else {
}
}
else {
echo 'No database connection has been established. Exiting execution.';
exit();
}
}
/*
* Setter for entriesSQL
*/
private function setEntriesSQL($entriesSQL) {
$this -> entriesSQL = $entriesSQL;
}
/*
* Getter for entriesSQL
*/
public function getEntriesSQL() {
return $this -> entriesSQL;
}
/*
* Setter for entry objects
*
*/
private function setEntryObjects() {
foreach ($this -> getEntriesSQL() as $key => $val) {
//entryID, entryUserID, entryTitle, entryTimeStart, entryTimeEnd
array_push($this -> entriesObjects, new entry($val['entryID'], $val['entryUserID'], $val['entryTitle'], $val['entryTimeStart'], $val['entryTimeEnd']));
}
}
/*
*
* Getter for entry objects
*
*/
public function getEntryObjects() {
return $this -> entriesObjects;
}
/*
*
* This function grabs events from SQL and return multidimensional-array of content.
*
*/
private function getEventsFromSQL() {
//Define the SQL query
$SQL = '...snippet...';
if ($entriesSQL = $this -> database -> read($SQL)) {
//Entries collected, return them.
return $entriesSQL;
}
else {
//Error occured. Log it and return false.
return false;
}
}
}
class entry {
var $entryID;
var $entryUserID;
var $entryTitle;
var $entryTimeStart;
var $entryTimeEnd;
public function __construct($entryID, $entryUserID, $entryTitle, $entryTimeStart, $entryTimeEnd) {
$this -> setEntryID($entryID);
$this -> setEntryUserID($entryUserID);
$this -> setEntryTitle($entryTitle);
$this -> setEntryTimeStart($entryTimeStart);
$this -> setEntryTimeEnd($entryTimeEnd);
}
/*
* Setter for entryID
*/
private function setEntryID($entryID) {
$this -> entryID = $entryID;
}
/*
* Getter for entryID
*/
public function getEntryID() {
return $this -> entryID;
}
/*
* Setter for entryUserID
*/
private function setEntryUserID($entryUserID) {
$this -> entryUserID = $entryUserID;
}
/*
* Getter for entryUserID
*/
public function getEntryUserID() {
return $this -> entryUserID;
}
/*
* Setter for entryTitle
*/
private function setEntryTitle($entryTitle) {
$this -> entryTitle = $entryTitle;
}
/*
* Getter for entryTitle
*/
public function getEntryTitle() {
return $this -> entryTitle;
}
/*
* Setter for entryTimeStart
*/
private function setEntryTimeStart($entryTimeStart) {
$this -> entryTimeStart = $entryTimeStart;
}
/*
* Getter for entryTimeStart
*/
public function getEntryTimeStart() {
return $this -> entryTimeStart;
}
/*
* Setter for entryTimeEnd
*/
private function setEntryTimeEnd($entryTimeEnd) {
$this -> entryTimeEnd = $entryTimeEnd;
}
/*
* Getter for entryTimeEnd
*/
public function getEntryTimeEnd() {
return $this -> entryTimeEnd;
}
}
现在,类“entryHandler”从我的控制器(在另一个PHP文件中)加载,如下所示:
//Instantiate calenderHandler and pass our database handler to it.
$entryHandler = new entryHandler($database);
//Load template
$template -> calendarEntries = $this -> renderEntries($entryHandler -> getEntryObjects());
/*
*
* This functions renders entries content for view.
* Returns string with content.
*
*/
private function renderEntries($entries) {
$entriesContent = '';
foreach ($entries as $entry) {
$entriesContent .= '{
title: "' . $entry -> getEntryTitle() . '",
start: "' . $entry -> getEntryTimeStart() . '",
end: "' . $entry -> getEntryTimeEnd() . '"
}, ';
}
//Right trim entries string, so that we do not add trailing comma to last entry in list.
$entriesContent = rtrim($entriesContent, ', ');
//And return content to parse it to view.
return $entriesContent;
}
}
这是一个糟糕的设计模式吗?有什么我应该用另一种方式做的吗?这段代码中有某种减少吗? - 我应该注意哪些事情?
感谢大家的时间。
问候, 费
答案 0 :(得分:3)
看起来你正在做的就是抛弃数据。 这可能不一定是错的,但您可以做其他事情。不是将所有SQL条目存储在数组中,而是如何:
因此,不是扔掉实际数据,而是扔掉包含数据的对象 这是一个好主意,因为它很容易改变数据的行为方式,或者添加数据提取方式,或者您可能需要的任何方式。
您正在做的事情,不一定是OOP。你只是在一个类中包含了很多函数。
创建类来执行您需要的操作,并使类尽可能小。每当你做一些你所在的课程而不是创造的东西时,就创建一个新的课程来处理你需要的东西。
OOP示例
了解如何进行OOP的一个好方法是观察其他人如何做到这一点。我建议你查看其他项目,看看他们是如何做的。
Symfony2 - 使用OOP的复杂php框架
Slim
CodeIgniter
LavarelPHP
答案 1 :(得分:0)
我非常同意Kao的回答。无论如何,如果你真的想自己做而不是使用任何DBAL,我建议你阅读一些docs on ORMs。
在你的代码中,允许构造一次处理很多东西是个坏主意。清洁并分开它们。使用依赖注入而不是在类/方法中创建对象。