我正在尝试将我的程序代码转换为oop。
<?php
$dbc = get_dbc();
$info = mysqli_query($dbc, "SELECT info_id, info_title FROM text") or die("Error: ".mysqli_error($dbc));
while ($info_row = mysqli_fetch_array($info))
{
$info_id = $info_row['info_id'];
$info_title = $info_row['info_title'];
?>
<div style="width: 100%;">
<div style="float: left;">
<?php echo $info_id; ?>
</div>
<div style="float: left;">
<?php echo $info_title; ?>
</div>
<div style="clear: both;"></div>
</div>
<?php } ?>
我对没有HTML样式的类/对象的不完全尝试:
<?php
class InfoTest {
private $info_id;
private $info_title;
public function __construct() {
$dbc = get_dbc();
$info = $dbc->query ("SELECT info_id, info_title FROM text");
if ($dbc->error) {
printf("Error: %s\n", $dbc->error);
}
while ($info_row = $info->fetch_array())
{
$info_id = $info_row['info_id'];
$info_title = $info_row['info_title'];
}
$info->free();
$this->info_id = $info_id;
$this->info_title = $info_title;
}
public function setInfoID() {
$this->info_id = $info_id;
}
public function getInfoID() {
return $this->info_id;
}
public function setInfoTitle() {
$this->info_title = $info_title;
}
public function getInfoTitle() {
return $this->info_title;
}
public function __destruct() {
}
}
?>
<?php
$display = new InfoTest();
echo $display->getInfoID();
echo $display->getInfoTitle();
?>
我的程序代码打印出来:1 One 2 Two。
我的oop代码打印出来:2 2
根据我的理解,oop以这种方式打印,因为$ info_id和$ info_title不是数组,只打印出最后存储的信息。
所以,如果我改变:
$info_id = $info_row['info_id'];
$info_title = $info_row['info_title'];
要:
$info_id[] = $info_row['info_id'];
$info_title[] = $info_row['info_title'];
打印数组,它会显示我想要的所有信息,但是如何以非数组形式显示它?
到目前为止我所做的是正确的还是我接近这个错误?
答案 0 :(得分:0)
因为info id是对象中的数组,所以获取值的相应函数应该采用偏移量。或者甚至更好的是你应该看看你的类实现迭代器,这样你就可以对你的对象进行预测
答案 1 :(得分:0)
你做错了。在您的程序示例中,您一次迭代一行数据;在你的OO示例中,如果将它们视为数组然后将它们打印出来,那么您将一次一行地查看数据。我不是将数据分成单独的ID和标题,而是将它们视为一个包(即类似于你在程序版本中的方式) - 一个id带有标题,而不是其他ID,对吧?
因此,例如,您可能有一个成员变量
private $texts = array();
然后在你的构造函数中,执行:
while ($info_row = $info->fetch_array()) {
$text = array(
'id' => $info_row['info_id'],
'title' => $info_row['info_title']
);
$this->texts[] = $text;
}
然后提供一个获取此数组数组的方法:
public function getTexts() {
return $this->texts;
}
最后,你可以像在程序示例中所做的那样迭代它:
<?php
$display = new InfoTest();
foreach ($display->getTexts() as $text) {
?>
<!-- html goes here -->
<?php echo $text['info_id']; ?>
<!-- more html -->
<?php echo $text['info_title']; ?>
<!-- other html -->
<?
}
?>
退一步 - 你可以问这一切是否真的有必要。程序化PHP没有任何本质上的错误 - 如果它完成了你需要它做的事情而且做得很清楚,你可能最好更喜欢简单过于复杂的。
答案 2 :(得分:0)
在切换到OOP之前,我首先将代码模块化并开始分割成彼此分离逻辑的功能部分,例如:数据库访问和模板:
<?php
/**
* infos provider
*
* @return array
*/
function get_infos()
{
$infos = array();
$dbc = get_dbc();
$info = mysqli_query($dbc, "SELECT info_id, info_title FROM text") or die("Error: ".mysqli_error($dbc));
while ($info_row = mysqli_fetch_array($info))
{
$infos[] = (object) $info_row;
}
return $infos;
}
foreach(get_infos() as $info)
{
?>
<div style="width: 100%;">
<div style="float: left;">
<?php echo $info->info_id; ?>
</div>
<div style="float: left;">
<?php echo $info->info_title; ?>
</div>
<div style="clear: both;"></div>
</div>
<?php } ?>
然后将数据库相关的函数移动到它自己的文件中,以将其与“模板”分离。完成后,您可以考虑进一步的重构步骤。我建议以下阅读(仅与指定的框架无关):When flat PHP meets symfony。